mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-26 16:34:08 +01:00 
			
		
		
		
	Compare commits
	
		
			1229 Commits
		
	
	
		
			5237-unifi
			...
			sidv/refac
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | e1a71296fe | ||
|   | 3f21f59f55 | ||
|   | 76557a628f | ||
|   | 0ae4f97036 | ||
|   | 218bfe1603 | ||
|   | 339c670839 | ||
|   | c5a19f6e85 | ||
|   | be57484573 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 0cb88c21dc | ||
|   | 0bc1f5296f | ||
|   | 4776f97f82 | ||
|   | 460db0aea7 | ||
|   | 02cf111995 | ||
|   | 14d9d92112 | ||
|   | fce77a19b0 | ||
|   | ef8c0025fd | ||
|   | 16847ea06c | ||
|   | be0bbe9950 | ||
|   | b503c2c758 | ||
|   | 1d14f4658d | ||
|   | c7382af161 | ||
|   | f6adca902f | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | d50a6cf75c | ||
|   | 2cebf09cf2 | ||
|   | 46419f7bfe | ||
|   | 43e8f831c0 | ||
|   | 760ea1e020 | ||
|   | 07d7704ef4 | ||
|   | a4878d05f0 | ||
|   | c5bcd2f22c | ||
|   | df1fba7fc5 | ||
|   | bb521f7af8 | ||
|   | f9818b8bd7 | ||
|   | dfcb4af18b | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 5c67e42a55 | ||
|   | 7441be09b5 | ||
|   | a75665c7bf | ||
|   | 4cb0f87b72 | ||
|   | 1e8cd63645 | ||
|   | 3860a99951 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 226b3bfa74 | ||
|   | a5559c6588 | ||
|   | de2c05cd54 | ||
|   | 6d916fb66f | ||
|   | 90b6df24a1 | ||
|   | 3e807e0131 | ||
|   | e2e2caa0e9 | ||
|   | b3dee343d1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 608f7afa70 | ||
|   | 58ef0ee174 | ||
|   | 2a76dc6409 | ||
|   | dc7e32eb10 | ||
|   | 6a649d347d | ||
|   | fd372941c7 | ||
|   | 1c8c95367d | ||
|   | b3dfc60fff | ||
|   | bb3b95f0bd | ||
|   | 4fc9028dc1 | ||
|   | 02cadd87ff | ||
|   | 1c105154a6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | daaeded0b5 | ||
|   | ed7d41a3cb | ||
|   | f052a3f686 | ||
|   | 11da07b735 | ||
|   | d01e180caf | ||
|   | 4c400966b4 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | f849c36942 | ||
|   | c83fc753a1 | ||
|   | eeeb5fcdd9 | ||
|   | cb85d50f61 | ||
|   | a52949318a | ||
|   | dd261a54df | ||
|   | f035db2feb | ||
|   | c6410472c8 | ||
|   | d807466780 | ||
|   | c8b9c4cebc | ||
|   | 741072a126 | ||
|   | be9123ee2b | ||
|   | 3f5afe8daf | ||
|   | 522de3abd8 | ||
|   | d37d77cc1a | ||
|   | 4740be6562 | ||
|   | a07f1f3337 | ||
|   | 02851fd672 | ||
|   | 233e36c988 | ||
|   | 2b12a658f6 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | b74842ceb3 | ||
|   | ca84f7d4a9 | ||
|   | 1892277273 | ||
|   | f12df395f8 | ||
|   | 89e82e4d97 | ||
|   | af2340d889 | ||
|   | 775a6381b4 | ||
|   | 38c6ad5ad6 | ||
|   | d63dc319c7 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | c5539e0aa0 | ||
|   | 14601b7871 | ||
|   | 7a86fd7b44 | ||
|   | 0b3522894a | ||
|   | aa0836aecc | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 78f9238865 | ||
|   | 5ca4fccbb0 | ||
|   | 7f2044024b | ||
|   | d2de9702c5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 92a8783d95 | ||
|   | 4bd1e5c524 | ||
|   | 10826055f3 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6cf050e6e5 | ||
|   | 52e1a36ffe | ||
|   | e83a95d3ed | ||
|   | 44561f57d3 | ||
|   | 4c26fe224b | ||
|   | 61af74609a | ||
|   | 9f2f3bd780 | ||
|   | 38bcbcdd0a | ||
|   | d8c340d9c5 | ||
|   | 8456d7b100 | ||
|   | 2fa044d484 | ||
|   | 4162a25425 | ||
|   | e26a38b619 | ||
|   | 92aa2859a0 | ||
|   | 1d8f524913 | ||
|   | 59991b70a1 | ||
|   | a6b877676e | ||
|   | 3c49c00f2b | ||
|   | c97716e780 | ||
|   | 355e218837 | ||
|   | a3145a32e7 | ||
|   | 8b6fb94835 | ||
|   | 83ea81d975 | ||
|   | aae9db92ee | ||
|   | 6c5b7ce9f4 | ||
|   | 8bb70ea493 | ||
|   | bff9f65c88 | ||
|   | 88607e8aa0 | ||
|   | 17c6ed6303 | ||
|   | bfd8c63daa | ||
|   | 6de7f1b088 | ||
|   | 3359d87115 | ||
|   | e8fdc965a2 | ||
|   | 67bcd3e0d6 | ||
|   | 9421f63775 | ||
|   | 01bf7af360 | ||
|   | 4754ed01ab | ||
|   | a2c262f940 | ||
|   | 7963ad9b20 | ||
|   | 5e34810335 | ||
|   | e44eb5258b | ||
|   | e564c395ba | ||
|   | 3d1af09090 | ||
|   | 1cc2f323de | ||
|   | 194684e27b | ||
|   | ee17e020cf | ||
|   | 2b8ef765e7 | ||
|   | dbe965303b | ||
|   | 3d9e919545 | ||
|   | 30eb02510b | ||
|   | 06aa72ec16 | ||
|   | cf45a35971 | ||
|   | a601d3bccf | ||
|   | f46a135458 | ||
|   | 82cc473801 | ||
|   | 9c41708d9e | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | a51d3aa2ad | ||
|   | 797d72b716 | ||
|   | dd0304387e | ||
|   | 80903ec281 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 1f373c8430 | ||
|   | 02d3bec856 | ||
|   | e111965411 | ||
|   | 41cf1262b2 | ||
|   | ddb51cdcbc | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | d053284536 | ||
|   | acc1e500d3 | ||
|   | c0187101e9 | ||
|   | 303f1f4545 | ||
|   | 750f58d7db | ||
|   | e5532c3418 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | a881d46178 | ||
|   | edb99c2842 | ||
|   | 4d04d1a8c3 | ||
|   | 1d1766b5c3 | ||
|   | 0ade03c4de | ||
|   | 2aa5089930 | ||
|   | 2259a59ac6 | ||
|   | d8d56df272 | ||
|   | ec29f749af | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 1951a0cdc8 | ||
|   | cc61629a8c | ||
|   | 5e75320d49 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b830e6151b | ||
|   | fd3c3fc022 | ||
|   | 94deacb1b5 | ||
|   | 571dfda629 | ||
|   | 6a3f1d194a | ||
|   | e5aebf3df6 | ||
|   | c95a0c7de4 | ||
|   | bf9842000f | ||
|   | 35c08985ee | ||
|   | ba95f394a3 | ||
|   | 2879f3775b | ||
|   | f7be983199 | ||
|   | 58524aceaa | ||
|   | ab25e9ea7d | ||
|   | 57d2d905ef | ||
|   | 64abf29ea8 | ||
|   | 73147196b1 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | c895109497 | ||
|   | 145acd0ee4 | ||
|   | 4c43d21196 | ||
|   | b4941aa4ce | ||
|   | aa259e03f2 | ||
|   | 0d7aaae0ff | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 9467735fab | ||
|   | 9e3aa705ae | ||
|   | 0f8cc48d03 | ||
|   | 95bd5dfdab | ||
|   | e6ce370cdd | ||
|   | 78346cbe84 | ||
|   | 9a953f7f80 | ||
|   | 14bb09a3db | ||
|   | 89fb65913d | ||
|   | 41a75005c8 | ||
|   | 54ecd7d423 | ||
|   | 352194c942 | ||
|   | 30e4ab99d9 | ||
|   | 5f0160c036 | ||
|   | 443c886050 | ||
|   | b7fd21e17a | ||
|   | 2f24f6271a | ||
|   | 6507624232 | ||
|   | e337331122 | ||
|   | 1d5f7ce08f | ||
|   | adedb5f803 | ||
|   | 9774c08336 | ||
|   | 525dcd4760 | ||
|   | d75661e49d | ||
|   | 52d6035c23 | ||
|   | 5a9221680f | ||
|   | 3a5fef3e50 | ||
|   | 8883008ca1 | ||
|   | 0eec89255f | ||
|   | 3d4c5d1a41 | ||
|   | 826faad37b | ||
|   | c078840c63 | ||
|   | 105b11fca2 | ||
|   | a259aeba27 | ||
|   | 8462f21c01 | ||
|   | 5d3a175ed6 | ||
|   | 69bec16080 | ||
|   | bfc4abeae2 | ||
|   | cd67fdf89d | ||
|   | 958fb6da2b | ||
|   | a6dbf0a9ee | ||
|   | 31b4ec3e10 | ||
|   | f7e4ee61c7 | ||
|   | 8e0bb994bb | ||
|   | b56fe796d6 | ||
|   | 7156cf4c71 | ||
|   | 426d311faa | ||
|   | 55aff88e9f | ||
|   | 32710c1d99 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 9bcf614a9a | ||
|   | 0520329fe0 | ||
|   | 10795b1d89 | ||
|   | 6bdeb7ac01 | ||
|   | 3f699ede9e | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 517c47b780 | ||
|   | e1c40bcf05 | ||
|   | 20c321076a | ||
|   | 87fa9e5289 | ||
|   | 9fa9bd9e93 | ||
|   | e44cdbd79d | ||
|   | 0edfab1048 | ||
|   | c68ae309e5 | ||
|   | 815e4b5748 | ||
|   | 6acbd9789a | ||
|   | f4decdee49 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 0b127eecd9 | ||
|   | 69c9a564f2 | ||
|   | 8ef24e5a18 | ||
|   | f5cc0dcaea | ||
|   | 007da4588b | ||
|   | 7056c20cca | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 7cda494bf4 | ||
|   | 2d8342261b | ||
|   | 336c3127ed | ||
|   | ef26fc921c | ||
|   | 0b672e2636 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 6209165b32 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | f3bb5c0c26 | ||
|   | 9cb09f1fb4 | ||
|   | cfeb794b34 | ||
|   | 1b7433b637 | ||
|   | 73f8d70b86 | ||
|   | 6a97f80cc3 | ||
|   | 3e922c83f0 | ||
|   | a45588ce7c | ||
|   | a176d64389 | ||
|   | e519686f01 | ||
|   | 59d6f04e4b | ||
|   | f4d4c784e4 | ||
|   | eb341bdfb6 | ||
|   | ee84ed4236 | ||
|   | f27feb268a | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 249e18314a | ||
|   | 115cb071b0 | ||
|   | 49323aa05b | ||
|   | d279f4e905 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | eaae85c6f8 | ||
|   | 62feced97a | ||
|   | d51ea942e1 | ||
|   | 4ac7c5edbb | ||
|   | 7d8143b917 | ||
|   | 790f71bb1a | ||
|   | a4b7e494db | ||
|   | 6ecdf7be68 | ||
|   | e0f7ea56e1 | ||
|   | 0ea88df662 | ||
|   | 56e9095619 | ||
|   | 1b69e121dc | ||
|   | 45e2366b5b | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 5309d21588 | ||
|   | c17f9be10e | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | a568f51024 | ||
|   | 8af76c2608 | ||
|   | dccd6121b1 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 0ecdbf4374 | ||
|   | 10bdc8dde6 | ||
|   | 16faef4613 | ||
|   | bed6c5dd0c | ||
|   | b3495219ae | ||
|   | 08d59d3d2b | ||
|   | 71753671e0 | ||
|   | 9746497673 | ||
|   | 882a2cc63e | ||
|   | 30d4632a0b | ||
|   | f29f5eb207 | ||
|   | 600247df79 | ||
|   | 904410f7f7 | ||
|   | fda092bbe9 | ||
|   | 75e8119c6a | ||
|   | 80c4b24803 | ||
|   | dd00575d57 | ||
|   | 33a809f09a | ||
|   | 28bd07fdeb | ||
|   | 8fa1fed8b5 | ||
|   | 5293b63f30 | ||
|   | 256a148bbf | ||
|   | eee1be474a | ||
|   | 0bd00764c4 | ||
|   | 63e9194c5d | ||
|   | 06310faa32 | ||
|   | 011c036350 | ||
|   | c9c821da5c | ||
|   | 8c8ed571d5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b0f7abb3a9 | ||
|   | c2c65b4df2 | ||
|   | 9b7f5ed963 | ||
|   | 75f755b823 | ||
|   | 1cfe987fa1 | ||
|   | 4cf7c97b8f | ||
|   | 3715254a78 | ||
|   | ab44053ba4 | ||
|   | 5c6f3e66a6 | ||
|   | 5e5265c8b0 | ||
|   | 2d481c4b73 | ||
|   | 13719aa694 | ||
|   | 9d9109a68c | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 5744c8614a | ||
|   | 9cf562476a | ||
|   | cb91c3f8a8 | ||
|   | c08fad6487 | ||
|   | 3b3b599c38 | ||
|   | 23329f1ee9 | ||
|   | 10e05f352e | ||
|   | e842b72aaa | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 43b0e808d0 | ||
|   | 286a3474d9 | ||
|   | 5aa8490e9e | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 49a77dda3a | ||
|   | 0049372b2e | ||
|   | 293411b005 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | efc1a0adc4 | ||
|   | e3b2a6949c | ||
|   | dbd4658028 | ||
|   | 940146fadd | ||
|   | efcafd99db | ||
|   | 6585380a4c | ||
|   | f653510d1b | ||
|   | 541cf251b2 | ||
|   | 755394ac9a | ||
|   | 2f1cfe0a31 | ||
|   | e0253b7768 | ||
|   | 5d1b50cb65 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | ed352debd5 | ||
|   | 221aedc5f5 | ||
|   | 4b195d17ed | ||
|   | 8e640da543 | ||
|   | 559be33ff7 | ||
|   | 0bfb42c68f | ||
|   | c95e997f8f | ||
|   | baafaf09df | ||
|   | db1b055c7f | ||
|   | 5ba5e30a47 | ||
|   | 7e9946eea8 | ||
|   | cac60db775 | ||
|   | 83ee06e9e7 | ||
|   | 534d3dd038 | ||
|   | f6333b4a5e | ||
|   | ac58785f50 | ||
|   | d08ef70e0f | ||
|   | ab4ba4cf2f | ||
|   | 1a1f668745 | ||
|   | 5c59505589 | ||
|   | 95274278f3 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 1532721f09 | ||
|   | 5db856cfb0 | ||
|   | b34dfe8f45 | ||
|   | 158f9925ce | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | dab8f08a9e | ||
|   | 313fefe704 | ||
|   | 17c0af1cf6 | ||
|   | 1bb09cc9a8 | ||
|   | 1e35341136 | ||
|   | 501a55d8f2 | ||
|   | ca57235e05 | ||
|   | a4e1479759 | ||
|   | e499f700ce | ||
|   | d559fcc90b | ||
|   | 35b98f2b89 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | e391966de8 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 4d10e3f258 | ||
|   | bf05d8781e | ||
|   | 2efe741924 | ||
|   | f04fa4d565 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 5bbf3678c5 | ||
|   | 83926c9707 | ||
|   | 7c26148252 | ||
|   | 49cb8d8388 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | eb3ed2a5e4 | ||
|   | 7d6a97e264 | ||
|   | 28f9181dd4 | ||
|   | 5013484924 | ||
|   | a10f46932f | ||
|   | 5deaef456e | ||
|   | 99f7d65f47 | ||
|   | a87f77339e | ||
|   | 078038b080 | ||
|   | ea9a06160c | ||
|   | 6c89763ef9 | ||
|   | 2cfdd1620a | ||
|   | b9f4faa916 | ||
|   | db1db1ab0e | ||
|   | cec28464ec | ||
|   | 21c636c4c6 | ||
|   | a2fba0284e | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | dd57030732 | ||
|   | efba4c18d1 | ||
|   | 48fd76e076 | ||
|   | f424a51133 | ||
|   | 46b8faddae | ||
|   | fdf376f9c8 | ||
|   | 46b7ee87dd | ||
|   | 14a94c0c51 | ||
|   | 24490f7789 | ||
|   | 09afb077f0 | ||
|   | 99ee235e75 | ||
|   | 029a444d32 | ||
|   | 8c4c92a861 | ||
|   | 19d46fc823 | ||
|   | ae2dc70385 | ||
|   | 0ad44c12fe | ||
|   | ad12fa7fff | ||
|   | 19cce07ab5 | ||
|   | 439dcb10b2 | ||
|   | 98cb8b998e | ||
|   | 1654a4b01c | ||
|   | 8e72611922 | ||
|   | a857d3807f | ||
|   | 3dc0af3159 | ||
|   | 53bff117aa | ||
|   | 2fe5e678bf | ||
|   | 4665b6bf15 | ||
|   | a9d317f997 | ||
|   | abf7ecd2ca | ||
|   | 9c032648c1 | ||
|   | 0e68788de4 | ||
|   | 44037c0c9d | ||
|   | 95e47d283e | ||
|   | 9dcda25355 | ||
|   | 225115ad07 | ||
|   | 0c316d9dc2 | ||
|   | 5ed5274256 | ||
|   | 283ec73ed9 | ||
|   | eac8459041 | ||
|   | 598de7019a | ||
|   | cc545f4433 | ||
|   | 61632f2d7f | ||
|   | 3d9a24dd28 | ||
|   | c4b92069ba | ||
|   | 8d8b6c1c33 | ||
|   | c892a89536 | ||
|   | 262790b22d | ||
|   | 89c782c094 | ||
|   | 7debe2fc59 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | fc44d1fcdd | ||
|   | 6e7a24e200 | ||
|   | 8815e447ad | ||
|   | c3ca401888 | ||
|   | 4da479388d | ||
|   | 0a0546e241 | ||
|   | c61159b63f | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 7a1c25bb3b | ||
|   | d0ea3dd82b | ||
|   | 36444ab242 | ||
|   | 0cf639cb1b | ||
|   | 90364a020b | ||
|   | 6e4b349c3a | ||
|   | 03d6531a7d | ||
|   | dd5866a4cb | ||
|   | 47ac57be69 | ||
|   | 52f5d95c81 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 792a62438f | ||
|   | 73e16d0857 | ||
|   | 4e8a7e0b4c | ||
|   | f1c066b68e | ||
|   | 121e27e850 | ||
|   | 3eaf8b7177 | ||
|   | 0b9554c675 | ||
|   | 0152ed7027 | ||
|   | 9134e1c837 | ||
|   | f233bfd75e | ||
|   | 4298a57297 | ||
|   | 6e8ea148bc | ||
|   | 777522e8d5 | ||
|   | a4007ffb80 | ||
|   | 10c25348f3 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 8ffd198d8b | ||
|   | 7c81096bbc | ||
|   | 3593fa63db | ||
|   | 037ba2fa9c | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 4d7b1e8eaf | ||
|   | f6e1515f66 | ||
|   | c5be9fd882 | ||
|   | 01b5935a4e | ||
|   | c1cd39bd65 | ||
|   | b2db7eb6bf | ||
|   | f4097dfd82 | ||
|   | 797877bcbf | ||
|   | db8a0028a6 | ||
|   | 50a535125e | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | ed07a9e896 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 43ffb00996 | ||
|   | 04e205bcb4 | ||
|   | 58aa4c467f | ||
|   | 0cc7eb7638 | ||
|   | 4e126e174b | ||
|   | de875c9e27 | ||
|   | 44875691db | ||
|   | c140e1a658 | ||
|   | 77118ad40c | ||
|   | bc3fe33428 | ||
|   | 754fa24104 | ||
|   | 69b3a9d3a2 | ||
|   | 3cfcb2da41 | ||
|   | 24ba5b73da | ||
|   | 8ef30a2642 | ||
|   | 8fdeb6d9d3 | ||
|   | 21efbbdbe8 | ||
|   | 4c3db653f5 | ||
|   | 1956d3d63c | ||
|   | 25efa4e63f | ||
|   | 6df6f5ab2c | ||
|   | c5dfa4213d | ||
|   | a48d970410 | ||
|   | 1168db6830 | ||
|   | f76cab1ba3 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 78fbf36c6e | ||
|   | 3ee19337ca | ||
|   | 90b7a3be63 | ||
|   | 3ac242978d | ||
|   | 94ee076aad | ||
|   | 7a7b41557d | ||
|   | d9d9cc9ddc | ||
|   | 0fbe5f2f10 | ||
|   | 4ec0dcfe1f | ||
|   | d82958d73d | ||
|   | 6b5286eff8 | ||
|   | 04c29e2a96 | ||
|   | 4e7d65062a | ||
|   | d5432ce811 | ||
|   | 262bf4e2b0 | ||
|   | f63eb45e7d | ||
|   | 22168ed760 | ||
|   | 210f8c2306 | ||
|   | 6205ddd430 | ||
|   | 36f2989249 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 4e40f29f33 | ||
|   | 0faeeb6411 | ||
|   | 99956b4283 | ||
|   | b93691be0e | ||
|   | 66e53df04b | ||
|   | 95c483934d | ||
|   | 9c5a8f7ef1 | ||
|   | e2f3041aa2 | ||
|   | 9926ae4e74 | ||
|   | 58463b5e80 | ||
|   | 7b51327b24 | ||
|   | 06dd350aab | ||
|   | 4f2085765d | ||
|   | eceae9b64c | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | bd0237369b | ||
|   | 79d50ebc76 | ||
|   | 98754b9fc6 | ||
|   | f813870e7d | ||
|   | 763a0c0d83 | ||
|   | d30444dae7 | ||
|   | c983c0605e | ||
|   | 2fa03ea369 | ||
|   | 53798beb96 | ||
|   | d36522648f | ||
|   | 1df90b4a05 | ||
|   | 6c1ae90972 | ||
|   | 8f970cddf9 | ||
|   | 299e559aa5 | ||
|   | a17e7d92d9 | ||
|   | b3a4e3f40e | ||
|   | b7acf94b41 | ||
|   | 9e5c3ec1b5 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 3539a35578 | ||
|   | d50150cbfa | ||
|   | 5550753193 | ||
|   | 394c6aea74 | ||
|   | 3febd7dfdf | ||
|   | ef895a3d8c | ||
|   | 8f5f7fc2a8 | ||
|   | c5eb07c83f | ||
|   | c673cf22bd | ||
|   | 4d401c127d | ||
|   | 3c119e4a52 | ||
|   | 303a160359 | ||
|   | 731b330e40 | ||
|   | 261aea3089 | ||
|   | 3cd5244949 | ||
|   | 31b8707819 | ||
|   | a0893b8e6c | ||
|   | 73aae9e86e | ||
|   | e1c8eb8a72 | ||
|   | 87b2084d97 | ||
|   | 9b42ffd070 | ||
|   | d2bbe83e08 | ||
|   | 61cfb156cc | ||
|   | bc546ef562 | ||
|   | 251b94647b | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | d24239530c | ||
|   | 2352137f6b | ||
|   | 3b2bb5a6ec | ||
|   | 4aeb2ae9a2 | ||
|   | 7f9d4cd079 | ||
|   | d73a090875 | ||
|   | aba306b685 | ||
|   | c49a1bf60c | ||
|   | d684e0d924 | ||
|   | 269284c6d7 | ||
|   | 62950c31a4 | ||
|   | e0d0cdcf1f | ||
|   | a93b8324ad | ||
|   | 39fdaef0a4 | ||
|   | db725c1de5 | ||
|   | 734f1add8e | ||
|   | 0f635ed344 | ||
|   | efe6affe64 | ||
|   | 9b9f4ea704 | ||
|   | f140d1ab45 | ||
|   | 02eb8dacb6 | ||
|   | afb69a3bb0 | ||
|   | 095e8ca9e7 | ||
|   | 95fb824cc7 | ||
|   | d4d7ca7d65 | ||
|   | 89e4de1dd0 | ||
|   | 537512fb27 | ||
|   | ba0d21682a | ||
|   | 729080f4b1 | ||
|   | ac48f01e25 | ||
|   | c2a479ab44 | ||
|   | 59aaa310dd | ||
|   | f4ce428d66 | ||
|   | 5aecd127bd | ||
|   | 2218929416 | ||
|   | 00603e7bac | ||
|   | 4c48b8cc54 | ||
|   | b807e330c8 | ||
|   | 04b15e7ece | ||
|   | 575c39e8a5 | ||
|   | 47601ac311 | ||
|   | 1990786c2c | ||
|   | 980c97a44c | ||
|   | 42177a3098 | ||
|   | 657e38f6e0 | ||
|   | 8fe0ed1d03 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6cd0585339 | ||
|   | e32151cc40 | ||
|   | 38e048b94e | ||
|   | 2a38d46fd9 | ||
|   | 9ed38ccf3a | ||
|   | 61cc2fc215 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 53e5f3a0c8 | ||
|   | 3f4c346e0c | ||
|   | e8ddae4882 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 09c966b271 | ||
|   | 933f3f391c | ||
|   | cfb5b88ee6 | ||
|   | f7ed91b5bd | ||
|   | 9cd44eb92c | ||
|   | aa24229786 | ||
|   | d0942d4897 | ||
|   | 3d789a0675 | ||
|   | 1d3f214109 | ||
|   | c4ce8543d3 | ||
|   | e51077c765 | ||
|   | c0d6d89330 | ||
|   | 1cdc73d270 | ||
|   | 1f44d11e15 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2fdcb0bfe6 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 6b336cbe77 | ||
|   | cdca63dcfe | ||
|   | b79191e39c | ||
|   | f30085c47e | ||
|   | ef25160b8e | ||
|   | 6c1e5aae92 | ||
|   | a0207f9195 | ||
|   | 346efdd384 | ||
|   | 6e5e5f9c61 | ||
|   | 871f0478c6 | ||
|   | 5dfc94e6f5 | ||
|   | ec2d9c9a08 | ||
|   | 281064f714 | ||
|   | 62757c529f | ||
|   | e57fee1f37 | ||
|   | 0d4c3e5f72 | ||
|   | 275dbe9b2e | ||
|   | 9f6a7b79ac | ||
|   | 3168084cf5 | ||
|   | 887e5803d8 | ||
|   | a386bd0b74 | ||
|   | 809fc1ce30 | ||
|   | f176b71c7c | ||
|   | 1af90946bc | ||
|   | d0eadebb99 | ||
|   | 1a95d48852 | ||
|   | 0b67cffdfa | ||
|   | d2e2017907 | ||
|   | 5460bc0a0c | ||
|   | ebd4da95cd | ||
|   | 4694ec08d3 | ||
|   | e26dbfe11a | ||
|   | 0d6552e63d | ||
|   | e683b8886a | ||
|   | 765e0cd35c | ||
|   | 880c4d4ed6 | ||
|   | c0bf6d8bbc | ||
|   | 2ae2686e34 | ||
|   | 25609d69c4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d809d8ba28 | ||
|   | c91dc7d0bc | ||
|   | 7bc75851cf | ||
|   | 1c0cb8b2d7 | ||
|   | 4d8e519298 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ee8893291c | ||
|   | fca35a3363 | ||
|   | 6f7c291512 | ||
|   | 0ad2282395 | ||
|   | 1d0e98dd62 | ||
|   | f20d89ee51 | ||
|   | 958204e831 | ||
|   | 82c247bb11 | ||
|   | 2800f555c7 | ||
|   | 86e4642046 | ||
|   | 2a56b640c0 | ||
|   | 2718cdae51 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 7175f5776f | ||
|   | d96dcd2529 | ||
|   | eae67a9696 | ||
|   | 5b47950f9f | ||
|   | 3c3d28d8ee | ||
|   | 61f55feca1 | ||
|   | 138ee49943 | ||
|   | 09c5c62e07 | ||
|   | 63850fde66 | ||
|   | f30d370e3b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9b77c8a1aa | ||
|   | 33da2b4057 | ||
|   | 932260f26b | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 8fe2d7c2e6 | ||
|   | 5b86fe38ae | ||
|   | e099e7d220 | ||
|   | 4bf52cc0c0 | ||
|   | bae2741e0e | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | aba109afa4 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 7dda1f5724 | ||
|   | 7389b9476b | ||
|   | bcc998cdae | ||
|   | 7db2de3bbd | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | c5cf5550c6 | ||
|   | dd18cd187f | ||
|   | c269f6fcee | ||
|   | fd8f3c3039 | ||
|   | eb714eb71a | ||
|   | 15c85efd88 | ||
|   | 5a6edf2fc4 | ||
|   | b3dfb5a21f | ||
|   | 99644bad17 | ||
|   | ab1a2ec411 | ||
|   | 38a7a47d11 | ||
|   | acb799cca0 | ||
|   | bfeab9ec0b | ||
|   | b6a03fca8b | ||
|   | 5868a96494 | ||
|   | 05a3806075 | ||
|   | 74c6fc35a8 | ||
|   | 594f2180a0 | ||
|   | b1b480a13b | ||
|   | 3681a7a4c1 | ||
|   | d2a73bcef4 | ||
|   | f9a20ab94e | ||
|   | dd7b071a94 | ||
|   | 2fb50a2d69 | ||
|   | 061aaf6f28 | ||
|   | 6ead2e16ea | ||
|   | 8950fb1795 | ||
|   | cdb87c193c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 587c3c8884 | ||
|   | 9343c6fd37 | ||
|   | 7c1cb236a6 | ||
|   | 8b5b1d4701 | ||
|   | 70dcfc83e6 | ||
|   | 3698c2b1e4 | ||
|   | df872427af | ||
|   | 720aef6ff0 | ||
|   | d71fe28a35 | ||
|   | 644199d0d0 | ||
|   | 207bc7c090 | ||
|   | 4bb75e5e37 | ||
|   | 84b51792d6 | ||
|   | 7a45ed8733 | ||
|   | cc6eae22b3 | ||
|   | 9cb959ba87 | ||
|   | aa279f6410 | ||
|   | 7afff877e5 | ||
|   | 4eba114c8b | ||
|   | 4434cf39a7 | ||
|   | 8bdd37ca44 | ||
|   | 0d110350f4 | ||
|   | d686cee2af | ||
|   | d9b16953f0 | ||
|   | 78dfffa1a7 | ||
|   | 192946337a | ||
|   | 6b7f33e1e5 | ||
|   | 728334b3ba | ||
|   | 515d880f0a | ||
|   | 60a30a3beb | ||
|   | e95e915d2b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | aa1432af5a | ||
|   | d44c65eb59 | ||
|   | c7e1b45377 | ||
|   | fe22a5f7b3 | ||
|   | e63b5a7de2 | ||
|   | 01fa7e6dad | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5dbe3ee444 | ||
|   | b263164c83 | ||
|   | a80dd711a7 | ||
|   | ce2f834683 | ||
|   | 4d6b92e5bf | ||
|   | 1b128cae77 | ||
|   | a94fe811dd | ||
|   | bde35b23f7 | ||
|   | 7f185d06df | ||
|   | 8ea7d5b80e | ||
|   | adf4351afd | ||
|   | f014061292 | ||
|   | 7f815693a0 | ||
|   | 03a634607a | ||
|   | fde668a3a6 | ||
|   | 6b7d78ebcf | ||
|   | 8db678a039 | ||
|   | 81419d1ef9 | ||
|   | 91670385f5 | ||
|   | 017a86bc0e | ||
|   | d12cdf4fbe | ||
|   | 9930d2927b | ||
|   | 8aa85d72de | ||
|   | 345e3cdaa7 | ||
|   | d0b712f0fb | ||
|   | caf8341445 | ||
|   | f3474fa778 | ||
|   | 772a7fcfbb | ||
|   | 9a638ece80 | ||
|   | 161506baf2 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 364511b133 | ||
|   | b5b2bc4aa5 | ||
|   | 934a761c37 | ||
|   | 2c2bd62e25 | ||
|   | 6e35c32cb2 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f78f3e79f7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 49c6c4d873 | ||
|   | 95d629e615 | ||
|   | efd5cf1c67 | ||
|   | 6337470b1b | ||
|   | 254ec07da9 | ||
|   | ec27270748 | ||
|   | 00467c646c | ||
|   | 771d3fcbbe | ||
|   | 775d8bb353 | ||
|   | 06377b8231 | ||
|   | 4e55f4cf3d | ||
|   | d5a03a9054 | ||
|   | f3a65f3178 | ||
|   | b27d83e0e7 | ||
|   | 55bd9e6efa | ||
|   | 8b8c0dd57c | ||
|   | d8d608fd99 | ||
|   | 2efb2565ad | ||
|   | c8a3290163 | ||
|   | 14a231767a | ||
|   | 803e9eb2bd | ||
|   | 29a3967c0e | ||
|   | cf72d33335 | ||
|   | 7534462966 | ||
|   | d4525331cb | ||
|   | 501cdbfcf7 | ||
|   | 13bba48e92 | ||
|   | f1bd8fa91b | ||
|   | d9a12997ce | ||
|   | 1fad9e6eef | ||
|   | d9b2934a50 | ||
|   | 6b87fb3418 | ||
|   | 444de0f133 | ||
|   | 51fc56b95d | ||
|   | 195e314c42 | ||
|   | 4c6e2783b0 | ||
|   | 4a50feb5d9 | ||
|   | 3f2e823330 | ||
|   | 16a15c4179 | ||
|   | 49cb10457e | ||
|   | 67c1eb34eb | ||
|   | 9cc59f0206 | ||
|   | 7167710800 | ||
|   | de115e2071 | ||
|   | e32e7f3256 | ||
|   | 8132f0a5b0 | ||
|   | 3c6ae36611 | ||
|   | b1b5ad3c9b | ||
|   | 3b2c751cd2 | ||
|   | 5e8ac1a66e | ||
|   | 02ef40223c | ||
|   | 69538aad09 | ||
|   | ce8256b8f6 | ||
|   | ced5cef2a3 | ||
|   | 93b41eddb9 | ||
|   | 39c6533881 | ||
|   | 0ba712f53c | ||
|   | 14622b0386 | ||
|   | 35797f867f | ||
|   | 3f0ababca6 | ||
|   | 6231682867 | ||
|   | 9400e46827 | ||
|   | b92eae5b34 | ||
|   | 5e6215d4f2 | ||
|   | 871a13aff8 | ||
|   | 7f2902594c | ||
|   | ceb487f2d4 | ||
|   | 6095aaae61 | ||
|   | c1052bd3c5 | ||
|   | a2cc86a414 | ||
|   | 2057649581 | ||
|   | ba0d91da32 | ||
|   | 63f81f36a9 | ||
|   | 8e46e10429 | ||
|   | 3411a6e46d | ||
|   | 115a4976ff | ||
|   | a796940de3 | ||
|   | 4b5e73102c | ||
|   | c5805383c7 | ||
|   | eb7d18dfca | ||
|   | eb0cb42f36 | ||
|   | 18e2879867 | ||
|   | 99552b3389 | ||
|   | 7391b05c43 | ||
|   | 0691c722c3 | ||
|   | 534a10edea | ||
|   | a46f993e3e | ||
|   | fc78ee0fc5 | ||
|   | ee6ae6a47a | ||
|   | 6d7b2b1e14 | ||
|   | 2117e71b51 | ||
|   | c3423beeda | ||
|   | de51bc40c7 | ||
|   | aa9f4a7760 | ||
|   | 9979ea1d74 | ||
|   | fc31b22eb0 | ||
|   | c221350d59 | ||
|   | 881a68241c | ||
|   | 469acbe810 | ||
|   | ab726f008c | ||
|   | 9b56cb3feb | ||
|   | cfacd3b2e1 | ||
|   | f45ae227a0 | ||
|   | 97be6cbd73 | ||
|   | ce3b0af03a | ||
|   | c7c1218e02 | ||
|   | f5bdbf22e7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1ab23d137f | ||
|   | b608083c2f | ||
|   | cba968ccc0 | ||
|   | 0f3778aea8 | ||
|   | ac5c61dbd4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6c785c9316 | ||
|   | 58483fb231 | ||
|   | 0d8c3fcf8c | ||
|   | 9f375139d5 | ||
|   | 5ba3696f95 | ||
|   | 0c49d2b84e | ||
|   | 42414e85d1 | ||
|   | 77a02fefe4 | ||
|   | 1e43ad1ee3 | ||
|   | cda41a1cdf | ||
|   | 1a199d630f | ||
|   | 51c07163aa | ||
|   | 9bbd3cab3c | ||
|   | 6f61a71dda | ||
|   | 3af4020cdc | ||
|   | d65e78f9e2 | ||
|   | 82b120e567 | ||
|   | d95c159b1f | ||
|   | c468319869 | ||
|   | 4de0182978 | ||
|   | 4b21e1e745 | ||
|   | 1601140511 | ||
|   | fb1942c2cf | ||
|   | 81d8b9d02e | ||
|   | 6db070197a | ||
|   | a331125187 | ||
|   | 66bc461fa1 | ||
|   | b69c9821bc | ||
|   | df72febc00 | ||
|   | 6d91ae4a09 | ||
|   | 5aced51f9e | ||
|   | f791ea00ef | ||
|   | e07fdfedb6 | ||
|   | 1096b185ee | ||
|   | fef433e844 | ||
|   | fe9fbd8618 | ||
|   | b031c6f182 | ||
|   | 5a93afa7ca | ||
|   | 2f792e33d6 | ||
|   | d408efdd1d | ||
|   | dc51a8f182 | ||
|   | e8d18189ac | ||
|   | a6276a94c3 | ||
|   | 85628f2148 | ||
|   | 1f70717a53 | ||
|   | 493bb8a80e | ||
|   | 788e7c96ff | ||
|   | caa0ff340d | ||
|   | 44688a20b6 | ||
|   | 3f1bba407e | ||
|   | 91e8bcaba9 | ||
|   | a35e62db14 | ||
|   | 66cd0b9621 | ||
|   | 6382dcf7c8 | ||
|   | 5587011f75 | ||
|   | 0044aa3029 | ||
|   | 9c3bcec7f0 | ||
|   | 63f9e95795 | ||
|   | 8f00555bf5 | ||
|   | 029b3c1101 | ||
|   | 2340a3b836 | ||
|   | d84b4403ab | ||
|   | 323f72ce33 | ||
|   | 6ae5fe7f17 | ||
|   | 460e027b6e | ||
|   | 406c0d869b | ||
|   | b6b2b3697d | ||
|   | 83f2663f68 | ||
|   | a6f3316ddb | ||
|   | 4a8c24a633 | ||
|   | 6ca6403878 | ||
|   | 5bd3a28667 | ||
|   | d52f4724fe | ||
|   | 618f7977ef | ||
|   | ecee23d8ba | ||
|   | 7ee22de5e2 | ||
|   | c904c7d21a | ||
|   | 0d1ef9de07 | ||
|   | 481f8186e4 | ||
|   | 5731b72795 | ||
|   | 92c05b9138 | ||
|   | dd7f8ac81b | ||
|   | 1afd0a199e | ||
|   | e2e652ae0f | ||
|   | a5d24e5da5 | ||
|   | 94512c0780 | ||
|   | ef83adb36e | ||
|   | 926762a800 | ||
|   | ec0e9b8680 | ||
|   | fc17733770 | ||
|   | a5281e0464 | ||
|   | a6dc1eaa40 | ||
|   | 9643e8f19c | ||
|   | bdca0a583e | ||
|   | a35152843f | ||
|   | f19a9d021f | ||
|   | 1b5bd999e2 | ||
|   | 36e4fcfdfe | ||
|   | 913dbee2e7 | ||
|   | d895a62565 | ||
|   | 50394e7af1 | ||
|   | 9981d3fc8b | ||
|   | 7763d9ceb8 | ||
|   | 8cbceb611a | ||
|   | 5f110e4cde | ||
|   | aaa4e8a794 | ||
|   | ea69d26a60 | ||
|   | ce3d0a23de | ||
|   | 7fbe1661ec | ||
|   | 1c4dd9b923 | ||
|   | 1b29135cc1 | ||
|   | b285466130 | ||
|   | 3754ac0872 | ||
|   | 83ca6897bd | ||
|   | d2d7f2bcb0 | ||
|   | 20f9abcc38 | ||
|   | 0417a8ddff | ||
|   | a85f36c3be | ||
|   | d9d4a677ab | ||
|   | 01297fa042 | ||
|   | 46fe731379 | ||
|   | cca1c41749 | ||
|   | 2c9c3b4571 | ||
|   | 4266b2e4ca | ||
|   | 0e63233845 | ||
|   | 9855bdbaaa | ||
|   | 51bdda0c34 | ||
|   | 37d799dd8e | ||
|   | c32116a21a | ||
|   | d6ccd93cf2 | ||
|   | af5e69327b | ||
|   | 20b03189df | ||
|   | 3d44eb0f42 | ||
|   | 3f039562b9 | ||
|   | a4cf503071 | ||
|   | 2315d3c90a | ||
|   | cf20ccb126 | ||
|   | e9ca618780 | ||
|   | 7c9e0e51da | ||
|   | 44f42b2a63 | ||
|   | 769d5660f5 | ||
|   | e26dea6416 | ||
|   | 3b2b8dacd8 | ||
|   | df94d3994d | ||
|   | 6f56d94c64 | ||
|   | 56c4f10607 | ||
|   | dfa71317ad | ||
|   | b09dc5db67 | ||
|   | 0049127bb7 | ||
|   | 5b6c95cea3 | ||
|   | 48e6901936 | ||
|   | 734bde3877 | ||
|   | cabb7b65e9 | ||
|   | 17fd681bdb | ||
|   | e852156b9f | ||
|   | b21fc9fe22 | ||
|   | 634b00b379 | ||
|   | b28f9f8136 | ||
|   | ac7891c14b | ||
|   | 2dfadca14c | ||
|   | 84f1d82aac | ||
|   | 1d27fac4d9 | ||
|   | a5d3164ea4 | ||
|   | cb302a08b8 | ||
|   | 497712a3fa | ||
|   | 073175e5f7 | ||
|   | 6bd1da219a | ||
|   | 0a14f2cffc | ||
|   | dcb1b4871f | ||
|   | baa6c9e4b9 | ||
|   | 251e808a29 | ||
|   | 22c0090979 | ||
|   | aef991bc49 | ||
|   | a4bbaf071e | ||
|   | 6d5791a63a | ||
|   | 2709c2d2e1 | ||
|   | 92d819ede5 | ||
|   | 36f52be3bf | ||
|   | f47bbee24a | ||
|   | 361e25ba34 | ||
|   | 46a37a6eea | ||
|   | b911bd3e42 | ||
|   | c239b6e311 | ||
|   | d1a3a84b6f | ||
|   | 10682ef31f | ||
|   | 0ab7a3d8ec | ||
|   | a493e2fbb3 | ||
|   | c7d41cd963 | ||
|   | e13e5f836e | ||
|   | 46346d2a51 | ||
|   | 830a58cebd | ||
|   | 6d69c26c8d | ||
|   | 5e214877a4 | ||
|   | cf88f0609d | ||
|   | e433b953f6 | ||
|   | 84bd20b04b | ||
|   | 6c6ce28f7d | ||
|   | e01acec12b | ||
|   | cc22e13e71 | ||
|   | 346ae22108 | ||
|   | 5a4d4972e2 | ||
|   | 03bbfa0b94 | ||
|   | d5c48e4be3 | ||
|   | fab6987601 | ||
|   | 9e3ebf1648 | ||
|   | f13beabdd0 | ||
|   | 1169cb9e85 | ||
|   | a2efa0d289 | ||
|   | 8691874dbb | ||
|   | db92b5a219 | ||
|   | 4fe2f31301 | ||
|   | fcd983d915 | 
| @@ -1,3 +1,9 @@ | ||||
| export interface PackageOptions { | ||||
|   name: string; | ||||
|   packageName: string; | ||||
|   file: string; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Shared common options for both ESBuild and Vite | ||||
|  */ | ||||
| @@ -27,4 +33,4 @@ export const packageOptions = { | ||||
|     packageName: 'mermaid-layout-elk', | ||||
|     file: 'layouts.ts', | ||||
|   }, | ||||
| } as const; | ||||
| } as const satisfies Record<string, PackageOptions>; | ||||
|   | ||||
| @@ -25,6 +25,7 @@ const MERMAID_CONFIG_DIAGRAM_KEYS = [ | ||||
|   'sankey', | ||||
|   'block', | ||||
|   'packet', | ||||
|   'architecture', | ||||
| ] as const; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -1,3 +1,4 @@ | ||||
| /* eslint-disable no-console */ | ||||
| import { packageOptions } from './common.js'; | ||||
| import { execSync } from 'child_process'; | ||||
|  | ||||
| @@ -5,11 +6,17 @@ const buildType = (packageName: string) => { | ||||
|   console.log(`Building types for ${packageName}`); | ||||
|   try { | ||||
|     const out = execSync(`tsc -p ./packages/${packageName}/tsconfig.json --emitDeclarationOnly`); | ||||
|     out.length > 0 && console.log(out.toString()); | ||||
|     if (out.length > 0) { | ||||
|       console.log(out.toString()); | ||||
|     } | ||||
|   } catch (e) { | ||||
|     console.error(e); | ||||
|     e.stdout.length > 0 && console.error(e.stdout.toString()); | ||||
|     e.stderr.length > 0 && console.error(e.stderr.toString()); | ||||
|     if (e.stdout.length > 0) { | ||||
|       console.error(e.stdout.toString()); | ||||
|     } | ||||
|     if (e.stderr.length > 0) { | ||||
|       console.error(e.stderr.toString()); | ||||
|     } | ||||
|   } | ||||
| }; | ||||
|  | ||||
|   | ||||
							
								
								
									
										8
									
								
								.changeset/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.changeset/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| # Changesets | ||||
|  | ||||
| Hello and welcome! This folder has been automatically generated by `@changesets/cli`, a build tool that works | ||||
| with multi-package repos, or single-package repos to help you version and publish your code. You can | ||||
| find the full documentation for it [in our repository](https://github.com/changesets/changesets) | ||||
|  | ||||
| We have a quick list of common questions to get you started engaging with this project in | ||||
| [our documentation](https://github.com/changesets/changesets/blob/main/docs/common-questions.md) | ||||
							
								
								
									
										12
									
								
								.changeset/config.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.changeset/config.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| { | ||||
|   "$schema": "https://unpkg.com/@changesets/config@3.0.0/schema.json", | ||||
|   "changelog": ["@changesets/changelog-github", { "repo": "mermaid-js/mermaid" }], | ||||
|   "commit": false, | ||||
|   "fixed": [], | ||||
|   "linked": [], | ||||
|   "access": "public", | ||||
|   "baseBranch": "master", | ||||
|   "updateInternalDependencies": "patch", | ||||
|   "bumpVersionsWithWorkspaceProtocolOnly": true, | ||||
|   "ignore": ["@mermaid-js/docs", "@mermaid-js/webpack-test", "@mermaid-js/mermaid-example-diagram"] | ||||
| } | ||||
| @@ -13,6 +13,7 @@ bqstring | ||||
| BQUOTE | ||||
| bramp | ||||
| BRKT | ||||
| brotli | ||||
| callbackargs | ||||
| callbackname | ||||
| classdef | ||||
| @@ -25,6 +26,7 @@ concat | ||||
| controlx | ||||
| controly | ||||
| CSSCLASS | ||||
| curv | ||||
| CYLINDEREND | ||||
| CYLINDERSTART | ||||
| DAGA | ||||
| @@ -54,6 +56,7 @@ GENERICTYPE | ||||
| getBoundarys | ||||
| grammr | ||||
| graphtype | ||||
| halign | ||||
| iife | ||||
| interp | ||||
| introdcued | ||||
| @@ -65,6 +68,7 @@ Kaufmann | ||||
| keyify | ||||
| LABELPOS | ||||
| LABELTYPE | ||||
| layoutstop | ||||
| lcov | ||||
| LEFTOF | ||||
| Lexa | ||||
| @@ -110,13 +114,17 @@ strikethrough | ||||
| stringifying | ||||
| struct | ||||
| STYLECLASS | ||||
| STYLEDEF | ||||
| STYLEOPTS | ||||
| subcomponent | ||||
| subcomponents | ||||
| subconfig | ||||
| SUBROUTINEEND | ||||
| SUBROUTINESTART | ||||
| Subschemas | ||||
| substr | ||||
| SVGG | ||||
| SVGSVG | ||||
| TAGEND | ||||
| TAGSTART | ||||
| techn | ||||
| @@ -127,11 +135,13 @@ titlevalue | ||||
| topbar | ||||
| TRAPEND | ||||
| TRAPSTART | ||||
| treemap | ||||
| ts-nocheck | ||||
| tsdoc | ||||
| typeof | ||||
| typestr | ||||
| unshift | ||||
| urlsafe | ||||
| verifymethod | ||||
| VERIFYMTHD | ||||
| WARN_DOCSDIR_DOESNT_MATCH | ||||
|   | ||||
| @@ -4,5 +4,6 @@ cpettitt | ||||
| Dong Cai | ||||
| Nikolay Rozhkov | ||||
| Peng Xiao | ||||
| Per Brolin | ||||
| subhash-halder | ||||
| Vinod Sidharth | ||||
|   | ||||
| @@ -28,6 +28,9 @@ dictionaryDefinitions: | ||||
|   - name: suggestions | ||||
|     words: | ||||
|       - none | ||||
|       - disp | ||||
|       - subproc | ||||
|       - tria | ||||
|     suggestWords: | ||||
|       - seperator:separator | ||||
|       - vertice:vertex | ||||
|   | ||||
| @@ -20,14 +20,17 @@ dagre-d3 | ||||
| Deepdwn | ||||
| Docsify | ||||
| Docsy | ||||
| Doctave | ||||
| DokuWiki | ||||
| dompurify | ||||
| elkjs | ||||
| fcose | ||||
| fontawesome | ||||
| Foswiki | ||||
| Gitea | ||||
| graphlib | ||||
| Grav | ||||
| icones | ||||
| iconify | ||||
| Inkdrop | ||||
| jiti | ||||
| @@ -56,12 +59,15 @@ redmine | ||||
| rehype | ||||
| roughjs | ||||
| rscratch | ||||
| shiki | ||||
| Slidev | ||||
| sparkline | ||||
| sphinxcontrib | ||||
| ssim | ||||
| stylis | ||||
| Swimm | ||||
| tsbuildinfo | ||||
| tseslint | ||||
| Tuleap | ||||
| Typora | ||||
| unocss | ||||
|   | ||||
| @@ -1,15 +1,17 @@ | ||||
| Adamiecki | ||||
| arrowend | ||||
| Bendpoints | ||||
| bmatrix | ||||
| braintree | ||||
| catmull | ||||
| compositTitleSize | ||||
| curv | ||||
| doublecircle | ||||
| elems | ||||
| gantt | ||||
| gitgraph | ||||
| gzipped | ||||
| handdrawn | ||||
| handDrawn | ||||
| knsv | ||||
| Knut | ||||
| marginx | ||||
| @@ -23,6 +25,7 @@ multigraph | ||||
| nodesep | ||||
| NOTEGROUP | ||||
| Pinterest | ||||
| procs | ||||
| rankdir | ||||
| ranksep | ||||
| rect | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| BRANDES | ||||
| circo | ||||
| handdrawnSeed | ||||
| handDrawn | ||||
| KOEPF | ||||
| neato | ||||
| newbranch | ||||
| validify | ||||
|   | ||||
| @@ -2,12 +2,16 @@ import { build } from 'esbuild'; | ||||
| import { mkdir, writeFile } from 'node:fs/promises'; | ||||
| import { packageOptions } from '../.build/common.js'; | ||||
| import { generateLangium } from '../.build/generateLangium.js'; | ||||
| import { MermaidBuildOptions, defaultOptions, getBuildConfig } from './util.js'; | ||||
| import type { MermaidBuildOptions } from './util.js'; | ||||
| import { defaultOptions, getBuildConfig } from './util.js'; | ||||
|  | ||||
| const shouldVisualize = process.argv.includes('--visualize'); | ||||
|  | ||||
| const buildPackage = async (entryName: keyof typeof packageOptions) => { | ||||
|   const commonOptions: MermaidBuildOptions = { ...defaultOptions, entryName } as const; | ||||
|   const commonOptions: MermaidBuildOptions = { | ||||
|     ...defaultOptions, | ||||
|     options: packageOptions[entryName], | ||||
|   } as const; | ||||
|   const buildConfigs: MermaidBuildOptions[] = [ | ||||
|     // package.mjs | ||||
|     { ...commonOptions }, | ||||
| @@ -35,11 +39,11 @@ const buildPackage = async (entryName: keyof typeof packageOptions) => { | ||||
|  | ||||
|   if (shouldVisualize) { | ||||
|     for (const { metafile } of results) { | ||||
|       if (!metafile) { | ||||
|       if (!metafile?.outputs) { | ||||
|         continue; | ||||
|       } | ||||
|       const fileName = Object.keys(metafile.outputs) | ||||
|         .filter((file) => !file.includes('chunks') && file.endsWith('js'))[0] | ||||
|         .find((file) => !file.includes('chunks') && file.endsWith('js'))! | ||||
|         .replace('dist/', ''); | ||||
|       // Upload metafile into https://esbuild.github.io/analyze/ | ||||
|       await writeFile(`stats/${fileName}.meta.json`, JSON.stringify(metafile)); | ||||
| @@ -48,13 +52,14 @@ const buildPackage = async (entryName: keyof typeof packageOptions) => { | ||||
| }; | ||||
|  | ||||
| const handler = (e) => { | ||||
|   // eslint-disable-next-line no-console | ||||
|   console.error(e); | ||||
|   process.exit(1); | ||||
| }; | ||||
|  | ||||
| const main = async () => { | ||||
|   await generateLangium(); | ||||
|   await mkdir('stats').catch(() => {}); | ||||
|   await mkdir('stats', { recursive: true }); | ||||
|   const packageNames = Object.keys(packageOptions) as (keyof typeof packageOptions)[]; | ||||
|   // it should build `parser` before `mermaid` because it's a dependency | ||||
|   for (const pkg of packageNames) { | ||||
|   | ||||
							
								
								
									
										34
									
								
								.esbuild/docs.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								.esbuild/docs.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| import { execFileSync } from 'child_process'; | ||||
| import { build } from 'esbuild'; | ||||
| import { rm } from 'fs/promises'; | ||||
| import { generateLangium } from '../.build/generateLangium.js'; | ||||
| import type { MermaidBuildOptions } from './util.js'; | ||||
| import { defaultOptions, getBuildConfig } from './util.js'; | ||||
|  | ||||
| const buildDocs = async () => { | ||||
|   const option: MermaidBuildOptions = { | ||||
|     ...defaultOptions, | ||||
|     options: { | ||||
|       file: 'rendering-util/rendering-elements/shapes.cli.ts', | ||||
|       name: 'mermaid-shapes', | ||||
|       packageName: 'mermaid', | ||||
|     }, | ||||
|   } as const; | ||||
|  | ||||
|   await build({ ...getBuildConfig(option), splitting: false, sourcemap: false }); | ||||
| }; | ||||
|  | ||||
| const handler = (e) => { | ||||
|   // eslint-disable-next-line no-console | ||||
|   console.error(e); | ||||
|   process.exit(1); | ||||
| }; | ||||
|  | ||||
| const main = async () => { | ||||
|   await generateLangium(); | ||||
|   await buildDocs().catch(handler); | ||||
|   execFileSync('node', ['packages/mermaid/dist/mermaid-shapes.esm.mjs']); | ||||
|   await rm('packages/mermaid/dist/mermaid-shapes.esm.mjs'); | ||||
| }; | ||||
|  | ||||
| void main(); | ||||
| @@ -1,6 +1,6 @@ | ||||
| import { readFile } from 'node:fs/promises'; | ||||
| import { transformJison } from '../.build/jisonTransformer.js'; | ||||
| import { Plugin } from 'esbuild'; | ||||
| import type { Plugin } from 'esbuild'; | ||||
|  | ||||
| export const jisonPlugin: Plugin = { | ||||
|   name: 'jison', | ||||
|   | ||||
| @@ -1,11 +1,12 @@ | ||||
| import express from 'express'; | ||||
| import type { NextFunction, Request, Response } from 'express'; | ||||
| import cors from 'cors'; | ||||
| import { getBuildConfig, defaultOptions } from './util.js'; | ||||
| import { context } from 'esbuild'; | ||||
| /* eslint-disable no-console */ | ||||
| import chokidar from 'chokidar'; | ||||
| import { generateLangium } from '../.build/generateLangium.js'; | ||||
| import cors from 'cors'; | ||||
| import { context } from 'esbuild'; | ||||
| import type { Request, Response } from 'express'; | ||||
| import express from 'express'; | ||||
| import { packageOptions } from '../.build/common.js'; | ||||
| import { generateLangium } from '../.build/generateLangium.js'; | ||||
| import { defaultOptions, getBuildConfig } from './util.js'; | ||||
|  | ||||
| const configs = Object.values(packageOptions).map(({ packageName }) => | ||||
|   getBuildConfig({ ...defaultOptions, minify: false, core: false, entryName: packageName }) | ||||
| @@ -19,16 +20,28 @@ const mermaidIIFEConfig = getBuildConfig({ | ||||
| }); | ||||
| configs.push(mermaidIIFEConfig); | ||||
|  | ||||
| const contexts = await Promise.all(configs.map((config) => context(config))); | ||||
| const contexts = await Promise.all( | ||||
|   configs.map(async (config) => ({ config, context: await context(config) })) | ||||
| ); | ||||
|  | ||||
| let rebuildCounter = 1; | ||||
| const rebuildAll = async () => { | ||||
|   console.time('Rebuild time'); | ||||
|   await Promise.all(contexts.map((ctx) => ctx.rebuild())).catch((e) => console.error(e)); | ||||
|   console.timeEnd('Rebuild time'); | ||||
|   const buildNumber = rebuildCounter++; | ||||
|   const timeLabel = `Rebuild ${buildNumber} Time (total)`; | ||||
|   console.time(timeLabel); | ||||
|   await Promise.all( | ||||
|     contexts.map(async ({ config, context }) => { | ||||
|       const buildVariant = `Rebuild ${buildNumber} Time (${Object.keys(config.entryPoints!)[0]} ${config.format})`; | ||||
|       console.time(buildVariant); | ||||
|       await context.rebuild(); | ||||
|       console.timeEnd(buildVariant); | ||||
|     }) | ||||
|   ).catch((e) => console.error(e)); | ||||
|   console.timeEnd(timeLabel); | ||||
| }; | ||||
|  | ||||
| let clients: { id: number; response: Response }[] = []; | ||||
| function eventsHandler(request: Request, response: Response, next: NextFunction) { | ||||
| function eventsHandler(request: Request, response: Response) { | ||||
|   const headers = { | ||||
|     'Content-Type': 'text/event-stream', | ||||
|     Connection: 'keep-alive', | ||||
| @@ -45,19 +58,20 @@ function eventsHandler(request: Request, response: Response, next: NextFunction) | ||||
|   }); | ||||
| } | ||||
|  | ||||
| let timeoutId: NodeJS.Timeout | undefined = undefined; | ||||
| let timeoutID: NodeJS.Timeout | undefined = undefined; | ||||
|  | ||||
| /** | ||||
|  * Debounce file change events to avoid rebuilding multiple times. | ||||
|  */ | ||||
| function handleFileChange() { | ||||
|   if (timeoutId !== undefined) { | ||||
|     clearTimeout(timeoutId); | ||||
|   if (timeoutID !== undefined) { | ||||
|     clearTimeout(timeoutID); | ||||
|   } | ||||
|   timeoutId = setTimeout(async () => { | ||||
|   // eslint-disable-next-line @typescript-eslint/no-misused-promises | ||||
|   timeoutID = setTimeout(async () => { | ||||
|     await rebuildAll(); | ||||
|     sendEventsToAll(); | ||||
|     timeoutId = undefined; | ||||
|     timeoutID = undefined; | ||||
|   }, 100); | ||||
| } | ||||
|  | ||||
| @@ -74,15 +88,16 @@ async function createServer() { | ||||
|       ignoreInitial: true, | ||||
|       ignored: [/node_modules/, /dist/, /docs/, /coverage/], | ||||
|     }) | ||||
|     // eslint-disable-next-line @typescript-eslint/no-misused-promises | ||||
|     .on('all', async (event, path) => { | ||||
|       // Ignore other events. | ||||
|       if (!['add', 'change'].includes(event)) { | ||||
|         return; | ||||
|       } | ||||
|       if (/\.langium$/.test(path)) { | ||||
|       console.log(`${path} changed. Rebuilding...`); | ||||
|       if (path.endsWith('.langium')) { | ||||
|         await generateLangium(); | ||||
|       } | ||||
|       console.log(`${path} changed. Rebuilding...`); | ||||
|       handleFileChange(); | ||||
|     }); | ||||
|  | ||||
| @@ -99,4 +114,4 @@ async function createServer() { | ||||
|   }); | ||||
| } | ||||
|  | ||||
| createServer(); | ||||
| void createServer(); | ||||
|   | ||||
| @@ -3,7 +3,7 @@ import { fileURLToPath } from 'url'; | ||||
| import type { BuildOptions } from 'esbuild'; | ||||
| import { readFileSync } from 'fs'; | ||||
| import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | ||||
| import { packageOptions } from '../.build/common.js'; | ||||
| import type { PackageOptions } from '../.build/common.js'; | ||||
| import { jisonPlugin } from './jisonPlugin.js'; | ||||
|  | ||||
| const __dirname = fileURLToPath(new URL('.', import.meta.url)); | ||||
| @@ -13,10 +13,10 @@ export interface MermaidBuildOptions extends BuildOptions { | ||||
|   core: boolean; | ||||
|   metafile: boolean; | ||||
|   format: 'esm' | 'iife'; | ||||
|   entryName: keyof typeof packageOptions; | ||||
|   options: PackageOptions; | ||||
| } | ||||
|  | ||||
| export const defaultOptions: Omit<MermaidBuildOptions, 'entryName'> = { | ||||
| export const defaultOptions: Omit<MermaidBuildOptions, 'entryName' | 'options'> = { | ||||
|   minify: false, | ||||
|   metafile: false, | ||||
|   core: false, | ||||
| @@ -52,11 +52,16 @@ const getFileName = (fileName: string, { core, format, minify }: MermaidBuildOpt | ||||
| }; | ||||
|  | ||||
| export const getBuildConfig = (options: MermaidBuildOptions): BuildOptions => { | ||||
|   const { core, entryName, metafile, format, minify } = options; | ||||
|   const { | ||||
|     core, | ||||
|     metafile, | ||||
|     format, | ||||
|     minify, | ||||
|     options: { name, file, packageName }, | ||||
|   } = options; | ||||
|   const external: string[] = ['require', 'fs', 'path']; | ||||
|   const { name, file, packageName } = packageOptions[entryName]; | ||||
|   const outFileName = getFileName(name, options); | ||||
|   let output: BuildOptions = buildOptions({ | ||||
|   const output: BuildOptions = buildOptions({ | ||||
|     absWorkingDir: resolve(__dirname, `../packages/${packageName}`), | ||||
|     entryPoints: { | ||||
|       [outFileName]: `src/${file}`, | ||||
|   | ||||
| @@ -1 +0,0 @@ | ||||
| .gitignore | ||||
							
								
								
									
										190
									
								
								.eslintrc.cjs
									
									
									
									
									
								
							
							
						
						
									
										190
									
								
								.eslintrc.cjs
									
									
									
									
									
								
							| @@ -1,190 +0,0 @@ | ||||
| module.exports = { | ||||
|   env: { | ||||
|     browser: true, | ||||
|     es6: true, | ||||
|     'jest/globals': true, | ||||
|     node: true, | ||||
|   }, | ||||
|   root: true, | ||||
|   parser: '@typescript-eslint/parser', | ||||
|   parserOptions: { | ||||
|     ecmaFeatures: { | ||||
|       experimentalObjectRestSpread: true, | ||||
|       jsx: true, | ||||
|     }, | ||||
|     tsconfigRootDir: __dirname, | ||||
|     sourceType: 'module', | ||||
|     ecmaVersion: 2022, | ||||
|     allowAutomaticSingleRunInference: true, | ||||
|     project: ['./tsconfig.eslint.json', './packages/*/tsconfig.json'], | ||||
|     parser: '@typescript-eslint/parser', | ||||
|   }, | ||||
|   extends: [ | ||||
|     'eslint:recommended', | ||||
|     'plugin:@typescript-eslint/recommended', | ||||
|     'plugin:json/recommended', | ||||
|     'plugin:markdown/recommended-legacy', | ||||
|     'plugin:@cspell/recommended', | ||||
|     'prettier', | ||||
|   ], | ||||
|   plugins: [ | ||||
|     '@typescript-eslint', | ||||
|     'no-only-tests', | ||||
|     'html', | ||||
|     'jest', | ||||
|     'jsdoc', | ||||
|     'json', | ||||
|     '@cspell', | ||||
|     'lodash', | ||||
|     'unicorn', | ||||
|   ], | ||||
|   ignorePatterns: [ | ||||
|     // this file is automatically generated by `pnpm run --filter mermaid types:build-config` | ||||
|     'packages/mermaid/src/config.type.ts', | ||||
|   ], | ||||
|   rules: { | ||||
|     curly: 'error', | ||||
|     'no-console': 'error', | ||||
|     'no-prototype-builtins': 'off', | ||||
|     'no-unused-vars': 'off', | ||||
|     'cypress/no-async-tests': 'off', | ||||
|     '@typescript-eslint/consistent-type-imports': 'error', | ||||
|     '@typescript-eslint/no-explicit-any': 'warn', | ||||
|     '@typescript-eslint/no-floating-promises': 'error', | ||||
|     '@typescript-eslint/no-misused-promises': 'error', | ||||
|     '@typescript-eslint/no-unused-vars': 'warn', | ||||
|     '@typescript-eslint/consistent-type-definitions': 'error', | ||||
|     '@typescript-eslint/ban-ts-comment': [ | ||||
|       'error', | ||||
|       { | ||||
|         'ts-expect-error': 'allow-with-description', | ||||
|         'ts-ignore': 'allow-with-description', | ||||
|         'ts-nocheck': 'allow-with-description', | ||||
|         'ts-check': 'allow-with-description', | ||||
|         minimumDescriptionLength: 10, | ||||
|       }, | ||||
|     ], | ||||
|     '@typescript-eslint/naming-convention': [ | ||||
|       'error', | ||||
|       { | ||||
|         selector: 'typeLike', | ||||
|         format: ['PascalCase'], | ||||
|         custom: { | ||||
|           regex: '^I[A-Z]', | ||||
|           match: false, | ||||
|         }, | ||||
|       }, | ||||
|     ], | ||||
|     'json/*': ['error', 'allowComments'], | ||||
|     '@cspell/spellchecker': [ | ||||
|       'error', | ||||
|       { | ||||
|         checkIdentifiers: true, | ||||
|         checkStrings: true, | ||||
|         checkStringTemplates: true, | ||||
|       }, | ||||
|     ], | ||||
|     'no-empty': [ | ||||
|       'error', | ||||
|       { | ||||
|         allowEmptyCatch: true, | ||||
|       }, | ||||
|     ], | ||||
|     'no-only-tests/no-only-tests': 'error', | ||||
|     'lodash/import-scope': ['error', 'method'], | ||||
|     'unicorn/better-regex': 'error', | ||||
|     'unicorn/no-abusive-eslint-disable': 'error', | ||||
|     'unicorn/no-array-push-push': 'error', | ||||
|     'unicorn/no-for-loop': 'error', | ||||
|     'unicorn/no-instanceof-array': 'error', | ||||
|     'unicorn/no-typeof-undefined': 'error', | ||||
|     'unicorn/no-unnecessary-await': 'error', | ||||
|     'unicorn/no-unsafe-regex': 'warn', | ||||
|     'unicorn/no-useless-promise-resolve-reject': 'error', | ||||
|     'unicorn/prefer-array-find': 'error', | ||||
|     'unicorn/prefer-array-flat-map': 'error', | ||||
|     'unicorn/prefer-array-index-of': 'error', | ||||
|     'unicorn/prefer-array-some': 'error', | ||||
|     'unicorn/prefer-default-parameters': 'error', | ||||
|     'unicorn/prefer-includes': 'error', | ||||
|     'unicorn/prefer-negative-index': 'error', | ||||
|     'unicorn/prefer-object-from-entries': 'error', | ||||
|     'unicorn/prefer-string-starts-ends-with': 'error', | ||||
|     'unicorn/prefer-string-trim-start-end': 'error', | ||||
|     'unicorn/string-content': 'error', | ||||
|     'unicorn/prefer-spread': 'error', | ||||
|     'unicorn/no-lonely-if': 'error', | ||||
|   }, | ||||
|   overrides: [ | ||||
|     { | ||||
|       files: ['cypress/**', 'demos/**'], | ||||
|       rules: { | ||||
|         'no-console': 'off', | ||||
|       }, | ||||
|     }, | ||||
|     { | ||||
|       files: ['*.{js,jsx,mjs,cjs}'], | ||||
|       extends: ['plugin:jsdoc/recommended'], | ||||
|       rules: { | ||||
|         'jsdoc/check-indentation': 'off', | ||||
|         'jsdoc/check-alignment': 'off', | ||||
|         'jsdoc/check-line-alignment': 'off', | ||||
|         'jsdoc/multiline-blocks': 'off', | ||||
|         'jsdoc/newline-after-description': 'off', | ||||
|         'jsdoc/tag-lines': 'off', | ||||
|         'jsdoc/require-param-description': 'off', | ||||
|         'jsdoc/require-param-type': 'off', | ||||
|         'jsdoc/require-returns': 'off', | ||||
|         'jsdoc/require-returns-description': 'off', | ||||
|       }, | ||||
|     }, | ||||
|     { | ||||
|       files: ['*.{ts,tsx}'], | ||||
|       plugins: ['tsdoc'], | ||||
|       rules: { | ||||
|         'no-restricted-syntax': [ | ||||
|           'error', | ||||
|           { | ||||
|             selector: 'TSEnumDeclaration', | ||||
|             message: | ||||
|               'Prefer using TypeScript union types over TypeScript enum, since TypeScript enums have a bunch of issues, see https://dev.to/dvddpl/whats-the-problem-with-typescript-enums-2okj', | ||||
|           }, | ||||
|         ], | ||||
|         'tsdoc/syntax': 'error', | ||||
|       }, | ||||
|     }, | ||||
|     { | ||||
|       files: ['*.spec.{ts,js}', 'cypress/**', 'demos/**', '**/docs/**'], | ||||
|       rules: { | ||||
|         'jsdoc/require-jsdoc': 'off', | ||||
|         '@typescript-eslint/no-unused-vars': 'off', | ||||
|       }, | ||||
|     }, | ||||
|     { | ||||
|       files: ['*.spec.{ts,js}', 'tests/**', 'cypress/**/*.js'], | ||||
|       rules: { | ||||
|         '@cspell/spellchecker': [ | ||||
|           'error', | ||||
|           { | ||||
|             checkIdentifiers: false, | ||||
|             checkStrings: false, | ||||
|             checkStringTemplates: false, | ||||
|           }, | ||||
|         ], | ||||
|       }, | ||||
|     }, | ||||
|     { | ||||
|       files: ['*.html', '*.md', '**/*.md/*'], | ||||
|       rules: { | ||||
|         'no-var': 'error', | ||||
|         'no-undef': 'off', | ||||
|         '@typescript-eslint/no-unused-vars': 'off', | ||||
|         '@typescript-eslint/no-floating-promises': 'off', | ||||
|         '@typescript-eslint/no-misused-promises': 'off', | ||||
|       }, | ||||
|       parserOptions: { | ||||
|         project: null, | ||||
|       }, | ||||
|     }, | ||||
|   ], | ||||
| }; | ||||
							
								
								
									
										8
									
								
								.github/lychee.toml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/lychee.toml
									
									
									
									
										vendored
									
									
								
							| @@ -41,7 +41,13 @@ exclude = [ | ||||
| "https://bundlephobia.com", | ||||
|  | ||||
| # Chrome webstore migration issue. Temporary | ||||
| "https://chromewebstore.google.com" | ||||
| "https://chromewebstore.google.com", | ||||
|  | ||||
| # Drupal 403 | ||||
| "https://(www.)?drupal.org", | ||||
|  | ||||
| # Swimm returns 404, eventhough the link is valid | ||||
| "https://docs.swimm.io" | ||||
| ] | ||||
|  | ||||
| # Exclude all private IPs from checking. | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
								
							| @@ -15,4 +15,4 @@ Make sure you | ||||
| - [ ] :book: have read the [contribution guidelines](https://mermaid.js.org/community/contributing.html) | ||||
| - [ ] :computer: have added necessary unit/e2e tests. | ||||
| - [ ] :notebook: have added documentation. Make sure [`MERMAID_RELEASE_VERSION`](https://mermaid.js.org/community/contributing.html#update-documentation) is used for all new features. | ||||
| - [ ] :bookmark: targeted `develop` branch | ||||
| - [ ] :butterfly: If your PR makes a change that should be noted in one or more packages' changelogs, generate a changeset by running `pnpm changeset` and following the prompts. Changesets that add features should be `minor` and those that fix bugs should be `patch`. Please prefix changeset messages with `feat:`, `fix:`, or `chore:`. | ||||
|   | ||||
							
								
								
									
										36
									
								
								.github/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										36
									
								
								.github/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,36 +0,0 @@ | ||||
| name-template: '$NEXT_PATCH_VERSION' | ||||
| tag-template: '$NEXT_PATCH_VERSION' | ||||
| categories: | ||||
|   - title: '🚨 **Breaking Changes**' | ||||
|     labels: | ||||
|       - 'Breaking Change' | ||||
|   - title: '🚀 Features' | ||||
|     labels: | ||||
|       - 'Type: Enhancement' | ||||
|       - 'feature' # deprecated, new PRs shouldn't have this | ||||
|   - title: '🐛 Bug Fixes' | ||||
|     labels: | ||||
|       - 'Type: Bug / Error' | ||||
|       - 'fix' # deprecated, new PRs shouldn't have this | ||||
|   - title: '🧰 Maintenance' | ||||
|     labels: | ||||
|       - 'Type: Other' | ||||
|       - 'chore' # deprecated, new PRs shouldn't have this | ||||
|   - title: '⚡️ Performance' | ||||
|     labels: | ||||
|       - 'Type: Performance' | ||||
|   - title: '📚 Documentation' | ||||
|     labels: | ||||
|       - 'Area: Documentation' | ||||
| change-template: '- $TITLE (#$NUMBER) @$AUTHOR' | ||||
| sort-by: title | ||||
| sort-direction: ascending | ||||
| exclude-labels: | ||||
|   - 'Skip changelog' | ||||
| no-changes-template: 'This release contains minor changes and bugfixes.' | ||||
| template: | | ||||
|   # Release Notes | ||||
|  | ||||
|   $CHANGES | ||||
|  | ||||
|   🎉 **Thanks to all contributors helping with this release!** 🎉 | ||||
							
								
								
									
										45
									
								
								.github/workflows/autofix.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								.github/workflows/autofix.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| name: autofix.ci # needed to securely identify the workflow | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     branches-ignore: | ||||
|       - 'renovate/**' | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||
|  | ||||
| jobs: | ||||
|   autofix: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|         # uses version from "packageManager" field in package.json | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
|       - name: Install Packages | ||||
|         run: | | ||||
|           pnpm install --frozen-lockfile | ||||
|         env: | ||||
|           CYPRESS_CACHE_FOLDER: .cache/Cypress | ||||
|  | ||||
|       - name: Fix Linting | ||||
|         shell: bash | ||||
|         run: pnpm -w run lint:fix | ||||
|  | ||||
|       - name: Sync `./src/config.type.ts` with `./src/schemas/config.schema.yaml` | ||||
|         shell: bash | ||||
|         run: pnpm run --filter mermaid types:build-config | ||||
|  | ||||
|       - name: Build Docs | ||||
|         working-directory: ./packages/mermaid | ||||
|         run: pnpm run docs:build | ||||
|  | ||||
|       - uses: autofix-ci/action@ff86a557419858bb967097bfc916833f5647fa8c # main | ||||
							
								
								
									
										8
									
								
								.github/workflows/build-docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/build-docs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,6 +8,8 @@ on: | ||||
|   pull_request: | ||||
|   merge_group: | ||||
|  | ||||
| concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| @@ -16,12 +18,12 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
|         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
|   | ||||
							
								
								
									
										49
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										49
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,49 +0,0 @@ | ||||
| name: Build | ||||
|  | ||||
| on: | ||||
|   push: {} | ||||
|   merge_group: | ||||
|   pull_request: | ||||
|     types: | ||||
|       - opened | ||||
|       - synchronize | ||||
|       - ready_for_review | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   build-mermaid: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|         # uses version from "packageManager" field in package.json | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
|       - name: Install Packages | ||||
|         run: | | ||||
|           pnpm install --frozen-lockfile | ||||
|         env: | ||||
|           CYPRESS_CACHE_FOLDER: .cache/Cypress | ||||
|  | ||||
|       - name: Run Build | ||||
|         run: pnpm run build | ||||
|  | ||||
|       - name: Upload Mermaid Build as Artifact | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: mermaid-build | ||||
|           path: packages/mermaid/dist | ||||
|  | ||||
|       - name: Upload Mermaid Mindmap Build as Artifact | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: mermaid-mindmap-build | ||||
|           path: packages/mermaid-mindmap/dist | ||||
							
								
								
									
										2
									
								
								.github/workflows/check-readme-in-sync.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/check-readme-in-sync.yml
									
									
									
									
										vendored
									
									
								
							| @@ -18,7 +18,7 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - name: Check for difference in README.md and docs/README.md | ||||
|         run: | | ||||
|   | ||||
							
								
								
									
										26
									
								
								.github/workflows/checks.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								.github/workflows/checks.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,26 +0,0 @@ | ||||
| on: | ||||
|   push: | ||||
|   merge_group: | ||||
|   pull_request: | ||||
|     types: | ||||
|       - opened | ||||
|       - synchronize | ||||
|       - ready_for_review | ||||
|  | ||||
| name: Static analysis on Test files | ||||
|  | ||||
| jobs: | ||||
|   check-tests: | ||||
|     runs-on: ubuntu-latest | ||||
|     name: check tests | ||||
|     if: github.repository_owner == 'mermaid-js' | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - uses: testomatio/check-tests@stable | ||||
|         with: | ||||
|           framework: cypress | ||||
|           tests: './cypress/e2e/**/**.spec.js' | ||||
|           token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           has-tests-label: true | ||||
							
								
								
									
										11
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -11,6 +11,9 @@ on: | ||||
|       - synchronize | ||||
|       - ready_for_review | ||||
|  | ||||
| permissions: # added using https://github.com/step-security/secure-repo | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   analyze: | ||||
|     name: Analyze | ||||
| @@ -29,11 +32,11 @@ jobs: | ||||
|  | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       # Initializes the CodeQL tools for scanning. | ||||
|       - name: Initialize CodeQL | ||||
|         uses: github/codeql-action/init@v3 | ||||
|         uses: github/codeql-action/init@2c779ab0d087cd7fe7b826087247c2c81f27bfa6 # v3.26.5 | ||||
|         with: | ||||
|           config-file: ./.github/codeql/codeql-config.yml | ||||
|           languages: ${{ matrix.language }} | ||||
| @@ -45,7 +48,7 @@ jobs: | ||||
|       # Autobuild attempts to build any compiled languages  (C/C++, C#, or Java). | ||||
|       # If this step fails, then you should remove it and run the build manually (see below) | ||||
|       - name: Autobuild | ||||
|         uses: github/codeql-action/autobuild@v3 | ||||
|         uses: github/codeql-action/autobuild@2c779ab0d087cd7fe7b826087247c2c81f27bfa6 # v3.26.5 | ||||
|  | ||||
|       # ℹ️ Command-line programs to run using the OS shell. | ||||
|       # 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun | ||||
| @@ -59,4 +62,4 @@ jobs: | ||||
|       #   make release | ||||
|  | ||||
|       - name: Perform CodeQL Analysis | ||||
|         uses: github/codeql-action/analyze@v3 | ||||
|         uses: github/codeql-action/analyze@2c779ab0d087cd7fe7b826087247c2c81f27bfa6 # v3.26.5 | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/dependency-review.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/dependency-review.yml
									
									
									
									
										vendored
									
									
								
							| @@ -15,6 +15,6 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: 'Checkout Repository' | ||||
|         uses: actions/checkout@v4 | ||||
|         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|       - name: 'Dependency Review' | ||||
|         uses: actions/dependency-review-action@v4 | ||||
|         uses: actions/dependency-review-action@5a2ce3f5b92ee19cbb1541a4984c76d921601d7c # v4.3.4 | ||||
|   | ||||
							
								
								
									
										10
									
								
								.github/workflows/e2e-applitools.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/e2e-applitools.yml
									
									
									
									
										vendored
									
									
								
							| @@ -11,6 +11,8 @@ on: | ||||
|         default: master | ||||
|         description: 'Parent branch to use for PRs' | ||||
|  | ||||
| concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| @@ -30,13 +32,13 @@ jobs: | ||||
|         run: | | ||||
|           echo "::error,title=Not using Applitools::APPLITOOLS_API_KEY is empty, disabling Applitools for this run." | ||||
|  | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|         # uses version from "packageManager" field in package.json | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
| @@ -52,7 +54,7 @@ jobs: | ||||
|           APPLITOOLS_SERVER_URL: 'https://eyesapi.applitools.com' | ||||
|  | ||||
|       - name: Cypress run | ||||
|         uses: cypress-io/github-action@v4 | ||||
|         uses: cypress-io/github-action@d79d2d530a66e641eb4a5f227e13bc985c60b964 # v4.2.2 | ||||
|         id: cypress | ||||
|         with: | ||||
|           start: pnpm run dev | ||||
|   | ||||
							
								
								
									
										113
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										113
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,18 +1,16 @@ | ||||
| # We use github cache to save snapshots between runs. | ||||
| # For PRs and MergeQueues, the target commit is used, and for push events, github.event.previous is used. | ||||
| # If a snapshot for a given Hash is not found, we checkout that commit, run the tests and cache the snapshots. | ||||
| # These are then downloaded before running the E2E, providing the reference snapshots. | ||||
| # If there are any errors, the diff image is uploaded to artifacts, and the user is notified. | ||||
|  | ||||
| name: E2E | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches-ignore: | ||||
|       - 'gh-readonly-queue/**' | ||||
|     branches: | ||||
|       - develop | ||||
|       - master | ||||
|       - release/** | ||||
|   pull_request: | ||||
|   merge_group: | ||||
|  | ||||
| concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| @@ -30,6 +28,7 @@ env: | ||||
|       ) ||  | ||||
|       github.event.before | ||||
|     }} | ||||
|   shouldRunParallel: ${{ secrets.CYPRESS_RECORD_KEY != '' && !(github.event_name == 'push' && github.ref == 'refs/heads/develop') }} | ||||
| jobs: | ||||
|   cache: | ||||
|     runs-on: ubuntu-latest | ||||
| @@ -37,15 +36,15 @@ jobs: | ||||
|       image: cypress/browsers:node-20.11.0-chrome-121.0.6167.85-1-ff-120.0-edge-121.0.2277.83-1 | ||||
|       options: --user 1001 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           node-version-file: '.node-version' | ||||
|       - name: Cache snapshots | ||||
|         id: cache-snapshot | ||||
|         uses: actions/cache@v4 | ||||
|         uses: actions/cache@0c45773b623bea8c8e75f6c82b208c3cf94ea4f9 # v4.0.2 | ||||
|         with: | ||||
|           save-always: true | ||||
|           path: ./cypress/snapshots | ||||
| @@ -54,13 +53,13 @@ jobs: | ||||
|       # If a snapshot for a given Hash is not found, we checkout that commit, run the tests and cache the snapshots. | ||||
|       - name: Switch to base branch | ||||
|         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} | ||||
|         uses: actions/checkout@v4 | ||||
|         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|         with: | ||||
|           ref: ${{ env.targetHash }} | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} | ||||
|         uses: cypress-io/github-action@v6 | ||||
|         uses: cypress-io/github-action@df7484c5ba85def7eef30db301afa688187bc378 # v6.7.2 | ||||
|         with: | ||||
|           # just perform install | ||||
|           runTests: false | ||||
| @@ -72,16 +71,6 @@ jobs: | ||||
|           mkdir -p cypress/snapshots/stats/base | ||||
|           mv stats cypress/snapshots/stats/base | ||||
|  | ||||
|       - name: Cypress run | ||||
|         uses: cypress-io/github-action@v6 | ||||
|         id: cypress-snapshot-gen | ||||
|         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} | ||||
|         with: | ||||
|           install: false | ||||
|           start: pnpm run dev | ||||
|           wait-on: 'http://localhost:9000' | ||||
|           browser: chrome | ||||
|  | ||||
|   e2e: | ||||
|     runs-on: ubuntu-latest | ||||
|     container: | ||||
| @@ -93,26 +82,26 @@ jobs: | ||||
|       matrix: | ||||
|         containers: [1, 2, 3, 4] | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|         # uses version from "packageManager" field in package.json | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
|       # These cached snapshots are downloaded, providing the reference snapshots. | ||||
|       - name: Cache snapshots | ||||
|         id: cache-snapshot | ||||
|         uses: actions/cache/restore@v4 | ||||
|         uses: actions/cache/restore@0c45773b623bea8c8e75f6c82b208c3cf94ea4f9 # v4.0.2 | ||||
|         with: | ||||
|           path: ./cypress/snapshots | ||||
|           key: ${{ runner.os }}-snapshots-${{ env.targetHash }} | ||||
|  | ||||
|       - name: Install dependencies | ||||
|         uses: cypress-io/github-action@v6 | ||||
|         uses: cypress-io/github-action@df7484c5ba85def7eef30db301afa688187bc378 # v6.7.2 | ||||
|         with: | ||||
|           runTests: false | ||||
|  | ||||
| @@ -128,11 +117,11 @@ jobs: | ||||
|       # Install NPM dependencies, cache them correctly | ||||
|       # and run all Cypress tests | ||||
|       - name: Cypress run | ||||
|         uses: cypress-io/github-action@v6 | ||||
|         uses: cypress-io/github-action@df7484c5ba85def7eef30db301afa688187bc378 # v6.7.2 | ||||
|         id: cypress | ||||
|         # If CYPRESS_RECORD_KEY is set, run in parallel on all containers | ||||
|         # Otherwise (e.g. if running from fork), we run on a single container only | ||||
|         if: ${{ ( env.CYPRESS_RECORD_KEY != '' ) || ( matrix.containers == 1 ) }} | ||||
|         if: ${{ env.shouldRunParallel == 'true' || ( matrix.containers == 1 ) }} | ||||
|         with: | ||||
|           install: false | ||||
|           start: pnpm run dev:coverage | ||||
| @@ -140,15 +129,19 @@ jobs: | ||||
|           browser: chrome | ||||
|           # Disable recording if we don't have an API key | ||||
|           # e.g. if this action was run from a fork | ||||
|           record: ${{ secrets.CYPRESS_RECORD_KEY != '' }} | ||||
|           parallel: ${{ secrets.CYPRESS_RECORD_KEY != '' }} | ||||
|           record: ${{ env.shouldRunParallel == 'true' }} | ||||
|           parallel: ${{ env.shouldRunParallel == 'true' }} | ||||
|         env: | ||||
|           CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} | ||||
|           VITEST_COVERAGE: true | ||||
|           CYPRESS_COMMIT: ${{ github.sha }} | ||||
|           ARGOS_TOKEN: ${{ secrets.ARGOS_TOKEN }} | ||||
|           ARGOS_PARALLEL: ${{ env.shouldRunParallel == 'true' }} | ||||
|           ARGOS_PARALLEL_TOTAL: 4 | ||||
|           ARGOS_PARALLEL_INDEX: ${{ matrix.containers }} | ||||
|  | ||||
|       - name: Upload Coverage to Codecov | ||||
|         uses: codecov/codecov-action@v4 | ||||
|         uses: codecov/codecov-action@e28ff129e5465c2c0dcc6f003fc735cb6ae0c673 # v4.5.0 | ||||
|         # Run step only pushes to develop and pull_requests | ||||
|         if: ${{ steps.cypress.conclusion == 'success' && (github.event_name == 'pull_request' || github.ref == 'refs/heads/develop')}} | ||||
|         with: | ||||
| @@ -158,55 +151,3 @@ jobs: | ||||
|           fail_ci_if_error: false | ||||
|           verbose: true | ||||
|           token: 6845cc80-77ee-4e17-85a1-026cd95e0766 | ||||
|  | ||||
|       # We upload the artifacts into numbered archives to prevent overwriting | ||||
|       - name: Upload Artifacts | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         if: ${{ always() }} | ||||
|         with: | ||||
|           name: snapshots-${{ matrix.containers }} | ||||
|           retention-days: 1 | ||||
|           path: ./cypress/snapshots | ||||
|  | ||||
|   combineArtifacts: | ||||
|     needs: e2e | ||||
|     runs-on: ubuntu-latest | ||||
|     if: ${{ always() }} | ||||
|     steps: | ||||
|       # Download all snapshot artifacts and merge them into a single folder | ||||
|       - name: Download All Artifacts | ||||
|         uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           path: snapshots | ||||
|           pattern: snapshots-* | ||||
|           merge-multiple: true | ||||
|  | ||||
|       # For successful push events, we save the snapshots cache | ||||
|       - name: Save snapshots cache | ||||
|         id: cache-upload | ||||
|         if: ${{ github.event_name == 'push' && needs.e2e.result != 'failure' }} | ||||
|         uses: actions/cache/save@v4 | ||||
|         with: | ||||
|           path: ./snapshots | ||||
|           key: ${{ runner.os }}-snapshots-${{ github.event.after }} | ||||
|  | ||||
|       - name: Flatten images to a folder | ||||
|         if: ${{ needs.e2e.result == 'failure'  }} | ||||
|         run: | | ||||
|           mkdir errors | ||||
|           cd snapshots | ||||
|           find . -mindepth 2 -type d -name "*__diff_output__*" -exec sh -c 'mv "$0"/*.png ../errors/' {} \; | ||||
|  | ||||
|       - name: Upload Error snapshots | ||||
|         if: ${{ needs.e2e.result == 'failure' }} | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         id: upload-artifacts | ||||
|         with: | ||||
|           name: error-snapshots | ||||
|           retention-days: 10 | ||||
|           path: errors/ | ||||
|  | ||||
|       - name: Notify Users | ||||
|         if: ${{ needs.e2e.result == 'failure' }} | ||||
|         run: | | ||||
|           echo "::error title=Visual tests failed::You can view images that failed by downloading the error-snapshots artifact: ${{ steps.upload-artifacts.outputs.artifact-url }}" | ||||
|   | ||||
							
								
								
									
										8
									
								
								.github/workflows/issue-triage.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/issue-triage.yml
									
									
									
									
										vendored
									
									
								
							| @@ -4,11 +4,17 @@ on: | ||||
|   issues: | ||||
|     types: [opened] | ||||
|  | ||||
| permissions: # added using https://github.com/step-security/secure-repo | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   triage: | ||||
|     permissions: | ||||
|       issues: write # for andymckay/labeler to label issues | ||||
|       pull-requests: write # for andymckay/labeler to label PRs | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: andymckay/labeler@1.0.4 | ||||
|       - uses: andymckay/labeler@e6c4322d0397f3240f0e7e30a33b5c5df2d39e90 # 1.0.4 | ||||
|         with: | ||||
|           repo-token: '${{ secrets.GITHUB_TOKEN }}' | ||||
|           add-labels: 'Status: Triage' | ||||
|   | ||||
							
								
								
									
										9
									
								
								.github/workflows/link-checker.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								.github/workflows/link-checker.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,6 +19,9 @@ on: | ||||
|     # * is a special character in YAML so you have to quote this string | ||||
|     - cron: '30 8 * * *' | ||||
|  | ||||
| permissions: # added using https://github.com/step-security/secure-repo | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   link-checker: | ||||
|     runs-on: ubuntu-latest | ||||
| @@ -26,17 +29,17 @@ jobs: | ||||
|       # lychee only uses the GITHUB_TOKEN to avoid rate-limiting | ||||
|       contents: read | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - name: Restore lychee cache | ||||
|         uses: actions/cache@v4 | ||||
|         uses: actions/cache@0c45773b623bea8c8e75f6c82b208c3cf94ea4f9 # v4.0.2 | ||||
|         with: | ||||
|           path: .lycheecache | ||||
|           key: cache-lychee-${{ github.sha }} | ||||
|           restore-keys: cache-lychee- | ||||
|  | ||||
|       - name: Link Checker | ||||
|         uses: lycheeverse/lychee-action@v1.9.3 | ||||
|         uses: lycheeverse/lychee-action@c053181aa0c3d17606addfe97a9075a32723548a # v1.9.3 | ||||
|         with: | ||||
|           args: >- | ||||
|             --config .github/lychee.toml | ||||
|   | ||||
							
								
								
									
										35
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										35
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							| @@ -4,26 +4,32 @@ on: | ||||
|   push: | ||||
|   merge_group: | ||||
|   pull_request: | ||||
|     types: | ||||
|       - opened | ||||
|       - synchronize | ||||
|       - ready_for_review | ||||
|   workflow_dispatch: | ||||
|  | ||||
| concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
|  | ||||
| jobs: | ||||
|   docker-lint: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: hadolint/hadolint-action@54c9adbab1582c2ef04b2016b760714a4bfde3cf # v3.1.0 | ||||
|         with: | ||||
|           verbose: true | ||||
|   lint: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|         # uses version from "packageManager" field in package.json | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
| @@ -83,14 +89,9 @@ jobs: | ||||
|         continue-on-error: ${{ github.event_name == 'push' }} | ||||
|         run: pnpm run docs:verify | ||||
|  | ||||
|       - name: Rebuild Docs | ||||
|         if: ${{ steps.verifyDocs.outcome == 'failure' && github.event_name == 'push' }} | ||||
|         working-directory: ./packages/mermaid | ||||
|         run: pnpm run docs:build | ||||
|  | ||||
|       - name: Commit changes | ||||
|         uses: EndBug/add-and-commit@v9 | ||||
|         if: ${{ steps.verifyDocs.outcome == 'failure' && github.event_name == 'push' }} | ||||
|       - uses: testomatio/check-tests@0ea638fcec1820cf2e7b9854fdbdd04128a55bd4 # stable | ||||
|         with: | ||||
|           message: 'Update docs' | ||||
|           add: 'docs/*' | ||||
|           framework: cypress | ||||
|           tests: './cypress/e2e/**/**.spec.js' | ||||
|           token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           has-tests-label: true | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/pr-labeler.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/pr-labeler.yml
									
									
									
									
										vendored
									
									
								
							| @@ -22,7 +22,7 @@ jobs: | ||||
|       pull-requests: write # write permission is required to label PRs | ||||
|     steps: | ||||
|       - name: Label PR | ||||
|         uses: release-drafter/release-drafter@v6 | ||||
|         uses: release-drafter/release-drafter@3f0f87098bd6b5c5b9a36d49c41d998ea58f9348 # v6.0.0 | ||||
|         with: | ||||
|           config-name: pr-labeler.yml | ||||
|           disable-autolabeler: false | ||||
|   | ||||
							
								
								
									
										12
									
								
								.github/workflows/publish-docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/workflows/publish-docs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -23,12 +23,12 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
|         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
| @@ -37,13 +37,13 @@ jobs: | ||||
|         run: pnpm install --frozen-lockfile | ||||
|  | ||||
|       - name: Setup Pages | ||||
|         uses: actions/configure-pages@v4 | ||||
|         uses: actions/configure-pages@1f0c5cde4bc74cd7e1254d0cb4de8d49e9068c7d # v4.0.0 | ||||
|  | ||||
|       - name: Run Build | ||||
|         run: pnpm --filter mermaid run docs:build:vitepress | ||||
|  | ||||
|       - name: Upload artifact | ||||
|         uses: actions/upload-pages-artifact@v3 | ||||
|         uses: actions/upload-pages-artifact@56afc609e74202658d3ffba0e8f6dda462b719fa # v3.0.1 | ||||
|         with: | ||||
|           path: packages/mermaid/src/vitepress/.vitepress/dist | ||||
|  | ||||
| @@ -56,4 +56,4 @@ jobs: | ||||
|     steps: | ||||
|       - name: Deploy to GitHub Pages | ||||
|         id: deployment | ||||
|         uses: actions/deploy-pages@v4 | ||||
|         uses: actions/deploy-pages@d6db90164ac5ed86f2b6aed7e0febac5b3c0c03e # v4.0.5 | ||||
|   | ||||
							
								
								
									
										23
									
								
								.github/workflows/release-draft.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/release-draft.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,23 +0,0 @@ | ||||
| name: Draft Release | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - master | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   draft-release: | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       contents: write # write permission is required to create a GitHub release | ||||
|       pull-requests: read # required to read PR titles/labels | ||||
|     steps: | ||||
|       - name: Draft Release | ||||
|         uses: release-drafter/release-drafter@v6 | ||||
|         with: | ||||
|           disable-autolabeler: true | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
| @@ -9,14 +9,14 @@ jobs: | ||||
|   publish-preview: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
| @@ -28,7 +28,7 @@ jobs: | ||||
|           CYPRESS_CACHE_FOLDER: .cache/Cypress | ||||
|  | ||||
|       - name: Install Json | ||||
|         run: npm i json --global | ||||
|         run: npm i json@11.0.0 --global | ||||
|  | ||||
|       - name: Publish | ||||
|         working-directory: ./packages/mermaid | ||||
|   | ||||
							
								
								
									
										43
									
								
								.github/workflows/release-preview.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								.github/workflows/release-preview.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| name: Preview release | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     branches: [develop] | ||||
|     types: [opened, synchronize, labeled, ready_for_review] | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.event.number }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|   actions: write | ||||
|  | ||||
| jobs: | ||||
|   preview: | ||||
|     if: ${{ github.repository_owner == 'mermaid-js' }} | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       contents: read | ||||
|       id-token: write | ||||
|       issues: write | ||||
|       pull-requests: write | ||||
|     name: Publish preview release | ||||
|     timeout-minutes: 5 | ||||
|     steps: | ||||
|       - name: Checkout Repo | ||||
|         uses: actions/checkout@f43a0e5ff2bd294095638e18286ca9a3d1956744 # v3.6.0 | ||||
|  | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
|       - name: Install Packages | ||||
|         run: pnpm install --frozen-lockfile | ||||
|  | ||||
|       - name: Publish packages | ||||
|         run: pnpx pkg-pr-new publish --pnpm './packages/*' | ||||
							
								
								
									
										47
									
								
								.github/workflows/release-publish.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										47
									
								
								.github/workflows/release-publish.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,47 +0,0 @@ | ||||
| name: Publish release | ||||
|  | ||||
| on: | ||||
|   release: | ||||
|     types: [published] | ||||
|  | ||||
| jobs: | ||||
|   publish: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: fregante/setup-git-user@v2 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|         # uses version from "packageManager" field in package.json | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
|       - name: Install Packages | ||||
|         run: | | ||||
|           pnpm install --frozen-lockfile | ||||
|           npm i json --global | ||||
|         env: | ||||
|           CYPRESS_CACHE_FOLDER: .cache/Cypress | ||||
|  | ||||
|       - name: Prepare release | ||||
|         run: | | ||||
|           VERSION=${GITHUB_REF:10} | ||||
|           echo "Preparing release $VERSION" | ||||
|           git checkout -t origin/release/$VERSION | ||||
|           npm version --no-git-tag-version --allow-same-version $VERSION | ||||
|           git add package.json | ||||
|           git commit -nm "Bump version $VERSION" | ||||
|           git checkout -t origin/master | ||||
|           git merge -m "Release $VERSION" --no-ff release/$VERSION | ||||
|           git push --no-verify | ||||
|  | ||||
|       - name: Publish | ||||
|         run: | | ||||
|           npm set //registry.npmjs.org/:_authToken $NPM_TOKEN | ||||
|           npm publish | ||||
|         env: | ||||
|           NPM_TOKEN: ${{ secrets.NPM_TOKEN }} | ||||
							
								
								
									
										46
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| name: Release | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - master | ||||
|  | ||||
| concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||
|  | ||||
| permissions: # added using https://github.com/step-security/secure-repo | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   release: | ||||
|     if: github.repository == 'mermaid-js/mermaid' | ||||
|     permissions: | ||||
|       contents: write # to create release (changesets/action) | ||||
|       id-token: write # OpenID Connect token needed for provenance | ||||
|       pull-requests: write # to create pull request (changesets/action) | ||||
|     name: Release | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout Repo | ||||
|         uses: actions/checkout@f43a0e5ff2bd294095638e18286ca9a3d1956744 # v3.6.0 | ||||
|  | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
|       - name: Install Packages | ||||
|         run: pnpm install --frozen-lockfile | ||||
|  | ||||
|       - name: Create Release Pull Request or Publish to npm | ||||
|         id: changesets | ||||
|         uses: changesets/action@aba318e9165b45b7948c60273e0b72fce0a64eb9 # v1.4.7 | ||||
|         with: | ||||
|           version: pnpm changeset:version | ||||
|           publish: pnpm changeset:publish | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|           NPM_TOKEN: ${{ secrets.NPM_TOKEN }} | ||||
|           NPM_CONFIG_PROVENANCE: true | ||||
							
								
								
									
										37
									
								
								.github/workflows/scorecard.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								.github/workflows/scorecard.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | ||||
| name: Scorecard supply-chain security | ||||
| on: | ||||
|   branch_protection_rule: | ||||
|   push: | ||||
|     branches: | ||||
|       - develop | ||||
|   schedule: | ||||
|     - cron: 29 15 * * 0 | ||||
| permissions: read-all | ||||
| jobs: | ||||
|   analysis: | ||||
|     name: Scorecard analysis | ||||
|     permissions: | ||||
|       id-token: write | ||||
|       security-events: write | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout code | ||||
|         uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 | ||||
|         with: | ||||
|           persist-credentials: false | ||||
|       - name: Run analysis | ||||
|         uses: ossf/scorecard-action@0864cf19026789058feabb7e87baa5f140aac736 # v2.3.1 | ||||
|         with: | ||||
|           results_file: results.sarif | ||||
|           results_format: sarif | ||||
|           publish_results: true | ||||
|       - name: Upload artifact | ||||
|         uses: actions/upload-artifact@97a0fba1372883ab732affbe8f94b823f91727db # v3.pre.node20 | ||||
|         with: | ||||
|           name: SARIF file | ||||
|           path: results.sarif | ||||
|           retention-days: 5 | ||||
|       - name: Upload to code-scanning | ||||
|         uses: github/codeql-action/upload-sarif@f0f3afee809481da311ca3a6ff1ff51d81dbeb24 # v3.26.4 | ||||
|         with: | ||||
|           sarif_file: results.sarif | ||||
							
								
								
									
										12
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,13 +9,13 @@ jobs: | ||||
|   unit-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|         # uses version from "packageManager" field in package.json | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||||
|         with: | ||||
|           cache: pnpm | ||||
|           node-version-file: '.node-version' | ||||
| @@ -38,8 +38,12 @@ jobs: | ||||
|         run: | | ||||
|           pnpm exec vitest run ./packages/mermaid/src/diagrams/gantt/ganttDb.spec.ts --coverage | ||||
|  | ||||
|       - name: Verify out-of-tree build with TypeScript | ||||
|         run: | | ||||
|           pnpm test:check:tsc | ||||
|  | ||||
|       - name: Upload Coverage to Codecov | ||||
|         uses: codecov/codecov-action@v4 | ||||
|         uses: codecov/codecov-action@e28ff129e5465c2c0dcc6f003fc735cb6ae0c673 # v4.5.0 | ||||
|         # Run step only pushes to develop and pull_requests | ||||
|         if: ${{ github.event_name == 'pull_request' || github.ref == 'refs/heads/develop' }} | ||||
|         with: | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/unlock-reopened-issues.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/unlock-reopened-issues.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,6 +8,6 @@ jobs: | ||||
|   triage: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: Dunning-Kruger/unlock-issues@v1 | ||||
|       - uses: Dunning-Kruger/unlock-issues@b06b7f7e5c3f2eaa1c6d5d89f40930e4d6d9699e # v1 | ||||
|         with: | ||||
|           repo-token: '${{ secrets.GITHUB_TOKEN }}' | ||||
|   | ||||
							
								
								
									
										8
									
								
								.github/workflows/update-browserlist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/update-browserlist.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,18 +8,18 @@ jobs: | ||||
|   update-browser-list: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: pnpm/action-setup@v2 | ||||
|       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||
|       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||
|       - run: npx update-browserslist-db@latest | ||||
|       - name: Commit changes | ||||
|         uses: EndBug/add-and-commit@v9 | ||||
|         uses: EndBug/add-and-commit@a94899bca583c204427a224a7af87c02f9b325d5 # v9.1.4 | ||||
|         with: | ||||
|           author_name: ${{ github.actor }} | ||||
|           author_email: ${{ github.actor }}@users.noreply.github.com | ||||
|           message: 'chore: update browsers list' | ||||
|           push: false | ||||
|       - name: Create Pull Request | ||||
|         uses: peter-evans/create-pull-request@v6 | ||||
|         uses: peter-evans/create-pull-request@c5a7806660adbe173f04e3e038b0ccdcd758773c # v6.1.0 | ||||
|         with: | ||||
|           branch: update-browserslist | ||||
|           title: Update Browserslist | ||||
|   | ||||
							
								
								
									
										2
									
								
								.hadolint.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								.hadolint.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| ignored: | ||||
|   - DL3002 # TODO: Last USER should not be root | ||||
| @@ -1,4 +1,2 @@ | ||||
| #!/bin/sh | ||||
| . "$(dirname "$0")/_/husky.sh" | ||||
|  | ||||
| #!/usr/bin/env sh | ||||
| NODE_OPTIONS="--max_old_space_size=8192" pnpm run pre-commit | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| import { build, InlineConfig, type PluginOption } from 'vite'; | ||||
| import type { InlineConfig } from 'vite'; | ||||
| import { build, type PluginOption } from 'vite'; | ||||
| import { resolve } from 'path'; | ||||
| import { fileURLToPath } from 'url'; | ||||
| import jisonPlugin from './jisonPlugin.js'; | ||||
| @@ -46,9 +47,10 @@ interface BuildOptions { | ||||
|  | ||||
| export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions): InlineConfig => { | ||||
|   const external: (string | RegExp)[] = ['require', 'fs', 'path']; | ||||
|   // eslint-disable-next-line no-console | ||||
|   console.log(entryName, packageOptions[entryName]); | ||||
|   const { name, file, packageName } = packageOptions[entryName]; | ||||
|   let output: OutputOptions = [ | ||||
|   const output: OutputOptions = [ | ||||
|     { | ||||
|       name, | ||||
|       format: 'esm', | ||||
| @@ -83,7 +85,6 @@ export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions) | ||||
|     plugins: [ | ||||
|       jisonPlugin(), | ||||
|       jsonSchemaPlugin(), // handles `.schema.yaml` files | ||||
|       // @ts-expect-error According to the type definitions, rollup plugins are incompatible with vite | ||||
|       typescript({ compilerOptions: { declaration: false } }), | ||||
|       istanbul({ | ||||
|         exclude: ['node_modules', 'test/', '__mocks__', 'generated'], | ||||
| @@ -121,10 +122,10 @@ await generateLangium(); | ||||
|  | ||||
| if (watch) { | ||||
|   await build(getBuildConfig({ minify: false, watch, core: false, entryName: 'parser' })); | ||||
|   build(getBuildConfig({ minify: false, watch, core: false, entryName: 'mermaid' })); | ||||
|   void build(getBuildConfig({ minify: false, watch, core: false, entryName: 'mermaid' })); | ||||
|   if (!mermaidOnly) { | ||||
|     build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-example-diagram' })); | ||||
|     build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-zenuml' })); | ||||
|     void build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-example-diagram' })); | ||||
|     void build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-zenuml' })); | ||||
|   } | ||||
| } else if (visualize) { | ||||
|   await build(getBuildConfig({ minify: false, watch, core: false, entryName: 'parser' })); | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { PluginOption } from 'vite'; | ||||
| import type { PluginOption } from 'vite'; | ||||
| import { getDefaults, getSchema, loadSchema } from '../.build/jsonSchema.js'; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -23,8 +23,9 @@ async function createServer() { | ||||
|   app.use(express.static('cypress/platform')); | ||||
|  | ||||
|   app.listen(9000, () => { | ||||
|     // eslint-disable-next-line no-console | ||||
|     console.log(`Listening on http://localhost:9000`); | ||||
|   }); | ||||
| } | ||||
|  | ||||
| createServer(); | ||||
| void createServer(); | ||||
|   | ||||
							
								
								
									
										15
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -1,2 +1,13 @@ | ||||
| FROM node:20.12.2-alpine3.19 AS base | ||||
| RUN wget -qO- https://get.pnpm.io/install.sh | ENV="$HOME/.shrc" SHELL="$(which sh)" sh - | ||||
| FROM node:20.12.2-alpine3.19@sha256:7a91aa397f2e2dfbfcdad2e2d72599f374e0b0172be1d86eeb73f1d33f36a4b2 | ||||
|  | ||||
| USER 0:0 | ||||
|  | ||||
| RUN corepack enable \ | ||||
|     && corepack enable pnpm | ||||
|  | ||||
| RUN apk add --no-cache git~=2.43.4 \ | ||||
|     && git config --add --system safe.directory /mermaid | ||||
|  | ||||
| ENV NODE_OPTIONS="--max_old_space_size=8192" | ||||
|  | ||||
| EXPOSE 9000 3333 | ||||
|   | ||||
							
								
								
									
										7
									
								
								FUNDING.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								FUNDING.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| { | ||||
|   "drips": { | ||||
|     "ethereum": { | ||||
|       "ownedBy": "0x0831DDFe60d009d9448CC976157b539089aB821E" | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @@ -35,6 +35,8 @@ Try Live Editor previews of future releases: <a href="https://develop.git.mermai | ||||
| [](https://www.npmjs.com/package/mermaid) | ||||
| [](https://discord.gg/AgrbSrBer3) | ||||
| [](https://twitter.com/mermaidjs_) | ||||
| [](https://argos-ci.com?utm_source=mermaid&utm_campaign=oss) | ||||
| [](https://securityscorecards.dev/viewer/?uri=github.com/mermaid-js/mermaid) | ||||
|  | ||||
| <img src="./img/header.png" alt="" /> | ||||
|  | ||||
| @@ -81,6 +83,10 @@ You can also use Mermaid within [GitHub](https://github.blog/2022-02-14-include- | ||||
|  | ||||
| For a more detailed introduction to Mermaid and some of its more basic uses, look to the [Beginner's Guide](https://mermaid.js.org/intro/getting-started.html), [Usage](https://mermaid.js.org/config/usage.html) and [Tutorials](https://mermaid.js.org/ecosystem/tutorials.html). | ||||
|  | ||||
| Our PR Visual Regression Testing is powered by [Argos](https://argos-ci.com/?utm_source=mermaid&utm_campaign=oss) with their generous Open Source plan. It makes the process of reviewing PRs with visual changes a breeze. | ||||
|  | ||||
| [](https://argos-ci.com?utm_source=mermaid&utm_campaign=oss) | ||||
|  | ||||
| In our release process we rely heavily on visual regression tests using [applitools](https://applitools.com/). Applitools is a great service which has been easy to use and integrate with our tests. | ||||
|  | ||||
| <a href="https://applitools.com/"> | ||||
|   | ||||
| @@ -2,6 +2,8 @@ import { defineConfig } from 'cypress'; | ||||
| import { addMatchImageSnapshotPlugin } from 'cypress-image-snapshot/plugin'; | ||||
| import coverage from '@cypress/code-coverage/task'; | ||||
| import eyesPlugin from '@applitools/eyes-cypress'; | ||||
| import { registerArgosTask } from '@argos-ci/cypress/task'; | ||||
|  | ||||
| export default eyesPlugin( | ||||
|   defineConfig({ | ||||
|     projectId: 'n2sma2', | ||||
| @@ -17,10 +19,17 @@ export default eyesPlugin( | ||||
|           } | ||||
|           return launchOptions; | ||||
|         }); | ||||
|         addMatchImageSnapshotPlugin(on, config); | ||||
|         // copy any needed variables from process.env to config.env | ||||
|         config.env.useAppli = process.env.USE_APPLI ? true : false; | ||||
|         config.env.useArgos = !!process.env.CI; | ||||
|  | ||||
|         if (config.env.useArgos) { | ||||
|           registerArgosTask(on, config, { | ||||
|             token: 'fc3a35cf5200db928d65b2047861582d9444032b', | ||||
|           }); | ||||
|         } else { | ||||
|           addMatchImageSnapshotPlugin(on, config); | ||||
|         } | ||||
|         // do not forget to return the changed config object! | ||||
|         return config; | ||||
|       }, | ||||
|   | ||||
| @@ -35,7 +35,7 @@ export const mermaidUrl = ( | ||||
|   }; | ||||
|   const objStr: string = JSON.stringify(codeObject); | ||||
|   let url = `http://localhost:9000/e2e.html?graph=${utf8ToB64(objStr)}`; | ||||
|   if (api) { | ||||
|   if (api && typeof graphStr === 'string') { | ||||
|     url = `http://localhost:9000/xss.html?graph=${graphStr}`; | ||||
|   } | ||||
|  | ||||
| @@ -54,16 +54,15 @@ export const imgSnapshotTest = ( | ||||
| ): void => { | ||||
|   const options: CypressMermaidConfig = { | ||||
|     ..._options, | ||||
|     fontFamily: _options.fontFamily || 'courier', | ||||
|     fontFamily: _options.fontFamily ?? 'courier', | ||||
|     // @ts-ignore TODO: Fix type of fontSize | ||||
|     fontSize: _options.fontSize || '16px', | ||||
|     fontSize: _options.fontSize ?? '16px', | ||||
|     sequence: { | ||||
|       ...(_options.sequence || {}), | ||||
|       ...(_options.sequence ?? {}), | ||||
|       actorFontFamily: 'courier', | ||||
|       noteFontFamily: | ||||
|         _options.sequence && _options.sequence.noteFontFamily | ||||
|           ? _options.sequence.noteFontFamily | ||||
|           : 'courier', | ||||
|       noteFontFamily: _options.sequence?.noteFontFamily | ||||
|         ? _options.sequence.noteFontFamily | ||||
|         : 'courier', | ||||
|       messageFontFamily: 'courier', | ||||
|     }, | ||||
|   }; | ||||
| @@ -74,7 +73,7 @@ export const imgSnapshotTest = ( | ||||
|  | ||||
| export const urlSnapshotTest = ( | ||||
|   url: string, | ||||
|   options: CypressMermaidConfig, | ||||
|   options: CypressMermaidConfig = {}, | ||||
|   _api = false, | ||||
|   validation?: any | ||||
| ): void => { | ||||
| @@ -95,18 +94,7 @@ export const openURLAndVerifyRendering = ( | ||||
|   options: CypressMermaidConfig, | ||||
|   validation?: any | ||||
| ): void => { | ||||
|   const useAppli: boolean = Cypress.env('useAppli'); | ||||
|   const name: string = (options.name || cy.state('runnable').fullTitle()).replace(/\s+/g, '-'); | ||||
|  | ||||
|   if (useAppli) { | ||||
|     cy.log(`Opening eyes ${Cypress.spec.name} --- ${name}`); | ||||
|     cy.eyesOpen({ | ||||
|       appName: 'Mermaid', | ||||
|       testName: name, | ||||
|       batchName: Cypress.spec.name, | ||||
|       batchId: batchId + Cypress.spec.name, | ||||
|     }); | ||||
|   } | ||||
|   const name: string = (options.name ?? cy.state('runnable').fullTitle()).replace(/\s+/g, '-'); | ||||
|  | ||||
|   cy.visit(url); | ||||
|   cy.window().should('have.property', 'rendered', true); | ||||
| @@ -116,11 +104,29 @@ export const openURLAndVerifyRendering = ( | ||||
|     cy.get('svg').should(validation); | ||||
|   } | ||||
|  | ||||
|   verifyScreenshot(name); | ||||
| }; | ||||
|  | ||||
| export const verifyScreenshot = (name: string): void => { | ||||
|   const useAppli: boolean = Cypress.env('useAppli'); | ||||
|   const useArgos: boolean = Cypress.env('useArgos'); | ||||
|  | ||||
|   if (useAppli) { | ||||
|     cy.log(`Opening eyes ${Cypress.spec.name} --- ${name}`); | ||||
|     cy.eyesOpen({ | ||||
|       appName: 'Mermaid', | ||||
|       testName: name, | ||||
|       batchName: Cypress.spec.name, | ||||
|       batchId: batchId + Cypress.spec.name, | ||||
|     }); | ||||
|     cy.log(`Check eyes ${Cypress.spec.name}`); | ||||
|     cy.eyesCheckWindow('Click!'); | ||||
|     cy.log(`Closing eyes ${Cypress.spec.name}`); | ||||
|     cy.eyesClose(); | ||||
|   } else if (useArgos) { | ||||
|     cy.argosScreenshot(name, { | ||||
|       threshold: 0.01, | ||||
|     }); | ||||
|   } else { | ||||
|     cy.matchImageSnapshot(name); | ||||
|   } | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { renderGraph } from '../../helpers/util.ts'; | ||||
| import { renderGraph, verifyScreenshot } from '../../helpers/util.ts'; | ||||
| describe('Configuration', () => { | ||||
|   describe('arrowMarkerAbsolute', () => { | ||||
|     it('should handle default value false of arrowMarkerAbsolute', () => { | ||||
| @@ -119,8 +119,7 @@ describe('Configuration', () => { | ||||
|       const url = 'http://localhost:9000/regression/issue-1874.html'; | ||||
|       cy.visit(url); | ||||
|       cy.window().should('have.property', 'rendered', true); | ||||
|       cy.get('svg').should('be.visible'); | ||||
|       cy.matchImageSnapshot( | ||||
|       verifyScreenshot( | ||||
|         'configuration.spec-should-not-taint-initial-configuration-when-using-multiple-directives' | ||||
|       ); | ||||
|     }); | ||||
| @@ -145,7 +144,7 @@ describe('Configuration', () => { | ||||
|           // none of the diagrams should be error diagrams | ||||
|           expect($svg).to.not.contain('Syntax error'); | ||||
|         }); | ||||
|       cy.matchImageSnapshot( | ||||
|       verifyScreenshot( | ||||
|         'configuration.spec-should-not-render-error-diagram-if-suppressErrorRendering-is-set' | ||||
|       ); | ||||
|     }); | ||||
| @@ -162,7 +161,7 @@ describe('Configuration', () => { | ||||
|           // some of the diagrams should be error diagrams | ||||
|           expect($svg).to.contain('Syntax error'); | ||||
|         }); | ||||
|       cy.matchImageSnapshot( | ||||
|       verifyScreenshot( | ||||
|         'configuration.spec-should-render-error-diagram-if-suppressErrorRendering-is-not-set' | ||||
|       ); | ||||
|     }); | ||||
|   | ||||
| @@ -1,14 +0,0 @@ | ||||
| import { urlSnapshotTest, openURLAndVerifyRendering } from '../../helpers/util.ts'; | ||||
|  | ||||
| describe('Flowchart elk', () => { | ||||
|   it('should use dagre as fallback', () => { | ||||
|     urlSnapshotTest('http://localhost:9000/flow-elk.html', { | ||||
|       name: 'flow-elk fallback to dagre', | ||||
|     }); | ||||
|   }); | ||||
|   it('should allow overriding with external package', () => { | ||||
|     urlSnapshotTest('http://localhost:9000/flow-elk.html?elk=true', { | ||||
|       name: 'flow-elk overriding dagre with elk', | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
| @@ -10,7 +10,6 @@ describe('XSS', () => { | ||||
|     cy.wait(1000).then(() => { | ||||
|       cy.get('.mermaid').should('exist'); | ||||
|     }); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('should not allow tags in the css', () => { | ||||
|   | ||||
| @@ -11,6 +11,27 @@ describe('Git Graph diagram', () => { | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   it('Should render subgraphs with title margins and edge labels', () => { | ||||
|     imgSnapshotTest( | ||||
|       `flowchart LR | ||||
|  | ||||
|           subgraph TOP | ||||
|               direction TB | ||||
|               subgraph B1 | ||||
|                   direction RL | ||||
|                   i1 --lb1-->f1 | ||||
|               end | ||||
|               subgraph B2 | ||||
|                   direction BT | ||||
|                   i2 --lb2-->f2 | ||||
|               end | ||||
|           end | ||||
|           A --lb3--> TOP --lb4--> B | ||||
|           B1 --lb5--> B2 | ||||
|         `, | ||||
|       { flowchart: { subGraphTitleMargin: { top: 10, bottom: 5 } } } | ||||
|     ); | ||||
|   }); | ||||
|   // it(`ultraFastTest`, function () { | ||||
|   //   // Navigate to the url we want to test | ||||
|   //   // ⭐️ Note to see visual bugs, run the test using the above URL for the 1st run. | ||||
|   | ||||
							
								
								
									
										180
									
								
								cypress/integration/rendering/architecture.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										180
									
								
								cypress/integration/rendering/architecture.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,180 @@ | ||||
| import { imgSnapshotTest, urlSnapshotTest } from '../../helpers/util.ts'; | ||||
|  | ||||
| describe.skip('architecture diagram', () => { | ||||
|   it('should render a simple architecture diagram with groups', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 group api(cloud)[API] | ||||
|  | ||||
|                 service db(database)[Database] in api | ||||
|                 service disk1(disk)[Storage] in api | ||||
|                 service disk2(disk)[Storage] in api | ||||
|                 service server(server)[Server] in api | ||||
|                 service gateway(internet)[Gateway]  | ||||
|  | ||||
|                 db L--R server | ||||
|                 disk1 T--B server | ||||
|                 disk2 T--B db | ||||
|                 server T--B gateway | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with groups within groups', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 group api[API] | ||||
|                 group public[Public API] in api | ||||
|                 group private[Private API] in api | ||||
|          | ||||
|                 service serv1(server)[Server] in public | ||||
|          | ||||
|                 service serv2(server)[Server] in private | ||||
|                 service db(database)[Database] in private | ||||
|          | ||||
|                 service gateway(internet)[Gateway] in api | ||||
|          | ||||
|                 serv1 B--T serv2 | ||||
|                 serv2 L--R db | ||||
|                 serv1 L--R gateway | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with the fallback icon', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 service unknown(iconnamedoesntexist)[Unknown Icon] | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with split directioning', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 service db(database)[Database] | ||||
|                 service s3(disk)[Storage] | ||||
|                 service serv1(server)[Server 1] | ||||
|                 service serv2(server)[Server 2] | ||||
|                 service disk(disk)[Disk] | ||||
|          | ||||
|                 db L--R s3 | ||||
|                 serv1 L--T s3 | ||||
|                 serv2 L--B s3 | ||||
|                 serv1 T--B disk | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with directional arrows', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 service servC(server)[Server 1] | ||||
|                 service servL(server)[Server 2] | ||||
|                 service servR(server)[Server 3] | ||||
|                 service servT(server)[Server 4] | ||||
|                 service servB(server)[Server 5] | ||||
|          | ||||
|                 servC (L--R) servL | ||||
|                 servC (R--L) servR | ||||
|                 servC (T--B) servT | ||||
|                 servC (B--T) servB | ||||
|          | ||||
|                 servL (T--L) servT | ||||
|                 servL (B--L) servB | ||||
|                 servR (T--R) servT | ||||
|                 servR (B--R) servB | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with group edges', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 group left_group(cloud)[Left] | ||||
|                 group right_group(cloud)[Right] | ||||
|                 group top_group(cloud)[Top] | ||||
|                 group bottom_group(cloud)[Bottom] | ||||
|                 group center_group(cloud)[Center] | ||||
|          | ||||
|                 service left_disk(disk)[Disk] in left_group | ||||
|                 service right_disk(disk)[Disk] in right_group | ||||
|                 service top_disk(disk)[Disk] in top_group | ||||
|                 service bottom_disk(disk)[Disk] in bottom_group | ||||
|                 service center_disk(disk)[Disk] in center_group | ||||
|          | ||||
|                 left_disk{group} (R--L) center_disk{group} | ||||
|                 right_disk{group} (L--R) center_disk{group} | ||||
|                 top_disk{group} (B--T) center_disk{group} | ||||
|                 bottom_disk{group} (T--B) center_disk{group} | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with edge labels', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 service servC(server)[Server 1] | ||||
|                 service servL(server)[Server 2] | ||||
|                 service servR(server)[Server 3] | ||||
|                 service servT(server)[Server 4] | ||||
|                 service servB(server)[Server 5] | ||||
|          | ||||
|                 servC L-[Label]-R servL | ||||
|                 servC R-[Label]-L servR | ||||
|                 servC T-[Label]-B servT | ||||
|                 servC B-[Label]-T servB | ||||
|          | ||||
|                 servL T-[Label]-L servT | ||||
|                 servL B-[Label]-L servB | ||||
|                 servR T-[Label]-R servT | ||||
|                 servR B-[Label]-R servB | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with simple junction edges', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 service left_disk(disk)[Disk] | ||||
|                 service top_disk(disk)[Disk] | ||||
|                 service bottom_disk(disk)[Disk] | ||||
|                 service top_gateway(internet)[Gateway] | ||||
|                 service bottom_gateway(internet)[Gateway] | ||||
|                 junction juncC | ||||
|                 junction juncR | ||||
|          | ||||
|                 left_disk R--L juncC | ||||
|                 top_disk B--T juncC | ||||
|                 bottom_disk T--B juncC | ||||
|                 juncC R--L juncR | ||||
|                 top_gateway B--T juncR | ||||
|                 bottom_gateway T--B juncR | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should render an architecture diagram with complex junction edges', () => { | ||||
|     imgSnapshotTest( | ||||
|       `architecture-beta | ||||
|                 group left | ||||
|                 group right | ||||
|                 service left_disk(disk)[Disk] in left | ||||
|                 service top_disk(disk)[Disk] in left | ||||
|                 service bottom_disk(disk)[Disk] in left | ||||
|                 service top_gateway(internet)[Gateway] in right | ||||
|                 service bottom_gateway(internet)[Gateway] in right | ||||
|                 junction juncC in left | ||||
|                 junction juncR in right | ||||
|          | ||||
|                 left_disk R--L juncC | ||||
|                 top_disk B--T juncC | ||||
|                 bottom_disk T--B juncC | ||||
|          | ||||
|          | ||||
|                 top_gateway (B--T juncR | ||||
|                 bottom_gateway (T--B juncR | ||||
|          | ||||
|                 juncC{group} R--L) juncR{group} | ||||
|             ` | ||||
|     ); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| describe('architecture - external', () => { | ||||
|   it('should allow adding external icons', () => { | ||||
|     urlSnapshotTest('http://localhost:9000/architecture-external.html'); | ||||
|   }); | ||||
| }); | ||||
| @@ -236,7 +236,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL16: width alignment - blocks shold be equal in width', () => { | ||||
|   it('BL17: width alignment - blocks shold be equal in width', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|     A("This is the text") | ||||
| @@ -247,7 +247,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL17: block types 1 - square, rounded and circle', () => { | ||||
|   it('BL18: block types 1 - square, rounded and circle', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|     A["square"] | ||||
| @@ -258,7 +258,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL18: block types 2 - odd, diamond and hexagon', () => { | ||||
|   it('BL19: block types 2 - odd, diamond and hexagon', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|     A>"rect_left_inv_arrow"] | ||||
| @@ -269,7 +269,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL19: block types 3 - stadium', () => { | ||||
|   it('BL20: block types 3 - stadium', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|     A(["stadium"]) | ||||
| @@ -278,7 +278,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL20: block types 4 - lean right, lean left, trapezoid and inv trapezoid', () => { | ||||
|   it('BL21: block types 4 - lean right, lean left, trapezoid and inv trapezoid', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|     A[/"lean right"/] | ||||
| @@ -290,7 +290,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL21: block types 1 - square, rounded and circle', () => { | ||||
|   it('BL22: block types 1 - square, rounded and circle', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|     A["square"] | ||||
| @@ -301,7 +301,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL22: sizing - it should be possible to make a block wider', () => { | ||||
|   it('BL23: sizing - it should be possible to make a block wider', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|       A("rounded"):2 | ||||
| @@ -312,7 +312,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL23: sizing - it should be possible to make a composite block wider', () => { | ||||
|   it('BL24: sizing - it should be possible to make a composite block wider', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|       block:2 | ||||
| @@ -324,7 +324,7 @@ describe('Block diagram', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('BL24: block in the middle with space on each side', () => { | ||||
|   it('BL25: block in the middle with space on each side', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|         columns 3 | ||||
| @@ -335,7 +335,7 @@ describe('Block diagram', () => { | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   it('BL25: space and an edge', () => { | ||||
|   it('BL26: space and an edge', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|   columns 5 | ||||
| @@ -345,7 +345,7 @@ describe('Block diagram', () => { | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   it('BL26: block sizes for regular blocks', () => { | ||||
|   it('BL27: block sizes for regular blocks', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|   columns 3 | ||||
| @@ -354,7 +354,7 @@ describe('Block diagram', () => { | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   it('BL27: composite block with a set width - f should use the available space', () => { | ||||
|   it('BL28: composite block with a set width - f should use the available space', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|   columns 3 | ||||
| @@ -363,11 +363,12 @@ describe('Block diagram', () => { | ||||
|       f | ||||
|   end | ||||
|   g | ||||
|       `, | ||||
|   `, | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   it('BL23: composite block with a set width - f and g should split the available space', () => { | ||||
|  | ||||
|   it('BL29: composite block with a set width - f and g should split the available space', () => { | ||||
|     imgSnapshotTest( | ||||
|       `block-beta | ||||
|   columns 3 | ||||
| @@ -379,7 +380,7 @@ describe('Block diagram', () => { | ||||
|   h | ||||
|   i | ||||
|   j | ||||
|       `, | ||||
|   `, | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import { imgSnapshotTest, renderGraph } from '../../helpers/util.ts'; | ||||
|  | ||||
| describe('C4 diagram', () => { | ||||
|   it('should render a simple C4Context diagram', () => { | ||||
|   it('C4.1 should render a simple C4Context diagram', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|       C4Context | ||||
| @@ -30,9 +30,8 @@ describe('C4 diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a simple C4Container diagram', () => { | ||||
|   it('C4.2 should render a simple C4Container diagram', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|       C4Container | ||||
| @@ -50,9 +49,8 @@ describe('C4 diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a simple C4Component diagram', () => { | ||||
|   it('C4.3 should render a simple C4Component diagram', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|       C4Component | ||||
| @@ -69,9 +67,8 @@ describe('C4 diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a simple C4Dynamic diagram', () => { | ||||
|   it('C4.4 should render a simple C4Dynamic diagram', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|       C4Dynamic | ||||
| @@ -93,9 +90,8 @@ describe('C4 diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a simple C4Deployment diagram', () => { | ||||
|   it('C4.5 should render a simple C4Deployment diagram', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|       C4Deployment | ||||
| @@ -117,6 +113,5 @@ describe('C4 diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
| @@ -76,7 +76,7 @@ describe('Class diagram V2', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('should render a simple class diagram with different visibilities', () => { | ||||
|   it('2.1 should render a simple class diagram with different visibilities', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|     classDiagram-v2 | ||||
| @@ -93,7 +93,7 @@ describe('Class diagram V2', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('should render multiple class diagrams', () => { | ||||
|   it('3: should render multiple class diagrams', () => { | ||||
|     imgSnapshotTest( | ||||
|       [ | ||||
|         ` | ||||
| @@ -581,4 +581,63 @@ class C13["With Città foreign language"] | ||||
|       { logLevel: 1, flowchart: { htmlLabels: false } } | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('renders a class diagram with a generic class in a namespace', () => { | ||||
|     const diagramDefinition = ` | ||||
|       classDiagram-v2 | ||||
|       namespace Company.Project.Module { | ||||
|         class GenericClass~T~ { | ||||
|           +addItem(item: T) | ||||
|           +getItem() T | ||||
|         } | ||||
|       } | ||||
|     `; | ||||
|  | ||||
|     imgSnapshotTest(diagramDefinition); | ||||
|   }); | ||||
|  | ||||
|   it('renders a class diagram with nested namespaces and relationships', () => { | ||||
|     const diagramDefinition = ` | ||||
|       classDiagram-v2 | ||||
|       namespace Company.Project.Module.SubModule { | ||||
|         class Report { | ||||
|           +generatePDF(data: List) | ||||
|           +generateCSV(data: List) | ||||
|         } | ||||
|       } | ||||
|       namespace Company.Project.Module { | ||||
|         class Admin { | ||||
|           +generateReport() | ||||
|         } | ||||
|       } | ||||
|       Admin --> Report : generates | ||||
|     `; | ||||
|  | ||||
|     imgSnapshotTest(diagramDefinition); | ||||
|   }); | ||||
|  | ||||
|   it('renders a class diagram with multiple classes and relationships in a namespace', () => { | ||||
|     const diagramDefinition = ` | ||||
|       classDiagram-v2 | ||||
|       namespace Company.Project.Module { | ||||
|         class User { | ||||
|           +login(username: String, password: String) | ||||
|           +logout() | ||||
|         } | ||||
|         class Admin { | ||||
|           +addUser(user: User) | ||||
|           +removeUser(user: User) | ||||
|           +generateReport() | ||||
|         } | ||||
|         class Report { | ||||
|           +generatePDF(reportData: List) | ||||
|           +generateCSV(reportData: List) | ||||
|         } | ||||
|       } | ||||
|       Admin --> User : manages | ||||
|       Admin --> Report : generates | ||||
|     `; | ||||
|  | ||||
|     imgSnapshotTest(diagramDefinition); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
| @@ -32,7 +32,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 1 } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('2: should render a simple class diagrams with cardinality', () => { | ||||
| @@ -61,7 +60,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('3: should render a simple class diagram with different visibilities', () => { | ||||
| @@ -79,7 +77,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('4: should render a simple class diagram with comments', () => { | ||||
| @@ -109,7 +106,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('5: should render a simple class diagram with abstract method', () => { | ||||
| @@ -121,7 +117,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('6: should render a simple class diagram with static method', () => { | ||||
| @@ -133,7 +128,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('7: should render a simple class diagram with Generic class', () => { | ||||
| @@ -153,7 +147,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('8: should render a simple class diagram with Generic class and relations', () => { | ||||
| @@ -174,7 +167,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('9: should render a simple class diagram with clickable link', () => { | ||||
| @@ -196,7 +188,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('10: should render a simple class diagram with clickable callback', () => { | ||||
| @@ -218,7 +209,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('11: should render a simple class diagram with return type on method', () => { | ||||
| @@ -233,7 +223,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('12: should render a simple class diagram with generic types', () => { | ||||
| @@ -249,7 +238,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('13: should render a simple class diagram with css classes applied', () => { | ||||
| @@ -267,7 +255,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('14: should render a simple class diagram with css classes applied directly', () => { | ||||
| @@ -283,7 +270,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('15: should render a simple class diagram with css classes applied to multiple classes', () => { | ||||
| @@ -298,7 +284,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('16: should render multiple class diagrams', () => { | ||||
| @@ -351,7 +336,6 @@ describe('Class diagram', () => { | ||||
|       ], | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   // it('17: should render a class diagram when useMaxWidth is true (default)', () => { | ||||
| @@ -421,7 +405,6 @@ describe('Class diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 1 } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('should render class diagram with newlines in title', () => { | ||||
| @@ -439,7 +422,6 @@ describe('Class diagram', () => { | ||||
|           +quack() | ||||
|         } | ||||
|       `); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('should render class diagram with many newlines in title', () => { | ||||
|   | ||||
| @@ -218,7 +218,6 @@ describe('Entity Relationship Diagram', () => { | ||||
|         `, | ||||
|       { loglevel: 1 } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('should render entities with keys', () => { | ||||
| @@ -322,4 +321,37 @@ ORDER ||--|{ LINE-ITEM : contains | ||||
|       { logLevel: 1 } | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('should render relationship labels with line breaks', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|     erDiagram | ||||
|       p[Person] { | ||||
|           string firstName | ||||
|           string lastName | ||||
|       } | ||||
|       a["Customer Account"] { | ||||
|           string email | ||||
|       } | ||||
|  | ||||
|       b["Customer Account Secondary"] { | ||||
|         string email | ||||
|       } | ||||
|        | ||||
|       c["Customer Account Tertiary"] { | ||||
|         string email | ||||
|       } | ||||
|        | ||||
|       d["Customer Account Nth"] { | ||||
|         string email | ||||
|       } | ||||
|  | ||||
|       p ||--o| a : "has<br />one" | ||||
|       p ||--o| b : "has<br />one<br />two" | ||||
|       p ||--o| c : "has<br />one<br/>two<br />three" | ||||
|       p ||--o| d : "has<br />one<br />two<br/>three<br />...<br/>Nth" | ||||
|       `, | ||||
|       { logLevel: 1 } | ||||
|     ); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
| @@ -3,7 +3,7 @@ import { imgSnapshotTest } from '../../helpers/util'; | ||||
| describe('Error Diagrams', () => { | ||||
|   beforeEach(() => { | ||||
|     cy.on('uncaught:exception', (err) => { | ||||
|       expect(err.message).to.include('Parse error'); | ||||
|       expect(err.message).to.include('error'); | ||||
|       // return false to prevent the error from | ||||
|       // failing this test | ||||
|       return false; | ||||
|   | ||||
| @@ -837,6 +837,26 @@ subgraph "\`**Two**\`" | ||||
|   in the hat\`") -- "\`1o **ipa**\`" --> d("The dog in the hog") | ||||
| end | ||||
|  | ||||
| `, | ||||
|           { flowchart: { titleTopMargin: 0 } } | ||||
|         ); | ||||
|       }); | ||||
|       it('Sub graphs and markdown strings', () => { | ||||
|         imgSnapshotTest( | ||||
|           `--- | ||||
| config: | ||||
|   layout: elk | ||||
| --- | ||||
|  | ||||
| flowchart LR | ||||
|  subgraph subgraph_ko6czgs5u["Untitled subgraph"] | ||||
|         D["Option 1"] | ||||
|   end | ||||
|     C{"Evaluate"} -- One --> D | ||||
|     C -- Two --> E(("Option 2")) | ||||
|     D --> E | ||||
|       A["A"] | ||||
|  | ||||
| `, | ||||
|           { flowchart: { titleTopMargin: 0 } } | ||||
|         ); | ||||
| @@ -855,7 +875,7 @@ describe('Title and arrow styling #4813', () => { | ||||
|       flowchart LR | ||||
|       A-->B | ||||
|       A-->C`, | ||||
|       { flowchart: { defaultRenderer: 'elk' } } | ||||
|       { layout: 'elk' } | ||||
|     ); | ||||
|     cy.get('svg').should((svg) => { | ||||
|       const title = svg[0].querySelector('text'); | ||||
| @@ -871,15 +891,14 @@ describe('Title and arrow styling #4813', () => { | ||||
|       B-.-oC | ||||
|       C==xD | ||||
|       D ~~~ A`, | ||||
|       { flowchart: { defaultRenderer: 'elk' } } | ||||
|       { layout: 'elk' } | ||||
|     ); | ||||
|     cy.get('svg').should((svg) => { | ||||
|       const edges = svg[0].querySelectorAll('.edges path'); | ||||
|       console.log(edges); | ||||
|       expect(edges[0]).to.have.attr('pattern', 'solid'); | ||||
|       expect(edges[1]).to.have.attr('pattern', 'dotted'); | ||||
|       expect(edges[2]).to.have.css('stroke-width', '3.5px'); | ||||
|       expect(edges[3]).to.have.css('stroke-width', '1.5px'); | ||||
|       expect(edges[0].getAttribute('class')).to.contain('edge-pattern-solid'); | ||||
|       expect(edges[1].getAttribute('class')).to.contain('edge-pattern-dotted'); | ||||
|       expect(edges[2].getAttribute('class')).to.contain('edge-thickness-thick'); | ||||
|       expect(edges[3].getAttribute('class')).to.contain('edge-thickness-invisible'); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
							
								
								
									
										1060
									
								
								cypress/integration/rendering/flowchart-handDrawn.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1060
									
								
								cypress/integration/rendering/flowchart-handDrawn.spec.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										142
									
								
								cypress/integration/rendering/flowchart-shape-alias.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										142
									
								
								cypress/integration/rendering/flowchart-shape-alias.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,142 @@ | ||||
| import { imgSnapshotTest } from '../../helpers/util.ts'; | ||||
|  | ||||
| const aliasSet1 = ['process', 'rect', 'proc', 'rectangle'] as const; | ||||
|  | ||||
| const aliasSet2 = ['event', 'rounded'] as const; | ||||
|  | ||||
| const aliasSet3 = ['stadium', 'pill', 'terminal'] as const; | ||||
|  | ||||
| const aliasSet4 = ['fr-rect', 'subproc', 'subprocess', 'framed-rectangle', 'subroutine'] as const; | ||||
|  | ||||
| const aliasSet5 = ['db', 'database', 'cylinder', 'cyl'] as const; | ||||
|  | ||||
| const aliasSet6 = ['diam', 'decision', 'diamond'] as const; | ||||
|  | ||||
| const aliasSet7 = ['hex', 'hexagon', 'prepare'] as const; | ||||
|  | ||||
| const aliasSet8 = ['lean-r', 'lean-right', 'in-out'] as const; | ||||
|  | ||||
| const aliasSet9 = ['lean-l', 'lean-left', 'out-in'] as const; | ||||
|  | ||||
| const aliasSet10 = ['trap-b', 'trapezoid-bottom', 'priority'] as const; | ||||
|  | ||||
| const aliasSet11 = ['trap-t', 'trapezoid-top', 'manual'] as const; | ||||
|  | ||||
| const aliasSet12 = ['dbl-circ', 'double-circle'] as const; | ||||
|  | ||||
| const aliasSet13 = ['notched-rectangle', 'card', 'notch-rect'] as const; | ||||
|  | ||||
| const aliasSet14 = [ | ||||
|   'lin-rect', | ||||
|   'lined-rectangle', | ||||
|   'lin-proc', | ||||
|   'lined-process', | ||||
|   'shaded-process', | ||||
| ] as const; | ||||
|  | ||||
| const aliasSet15 = ['sm-circ', 'small-circle', 'start'] as const; | ||||
|  | ||||
| const aliasSet16 = ['fr-circ', 'framed-circle', 'stop'] as const; | ||||
|  | ||||
| const aliasSet17 = ['fork', 'join'] as const; | ||||
| // brace-r', 'braces' | ||||
| const aliasSet18 = ['comment', 'brace-l'] as const; | ||||
|  | ||||
| const aliasSet19 = ['bolt', 'com-link', 'lightning-bolt'] as const; | ||||
|  | ||||
| const aliasSet20 = ['doc', 'document'] as const; | ||||
|  | ||||
| const aliasSet21 = ['delay', 'half-rounded-rectangle'] as const; | ||||
|  | ||||
| const aliasSet22 = ['h-cyl', 'das', 'horizontal-cylinder'] as const; | ||||
|  | ||||
| const aliasSet23 = ['lin-cyl', 'disk', 'lined-cylinder'] as const; | ||||
|  | ||||
| const aliasSet24 = ['curv-trap', 'display', 'curved-trapezoid'] as const; | ||||
|  | ||||
| const aliasSet25 = ['div-rect', 'div-proc', 'divided-rectangle', 'divided-process'] as const; | ||||
|  | ||||
| const aliasSet26 = ['extract', 'tri', 'triangle'] as const; | ||||
|  | ||||
| const aliasSet27 = ['win-pane', 'internal-storage', 'window-pane'] as const; | ||||
|  | ||||
| const aliasSet28 = ['f-circ', 'junction', 'filled-circle'] as const; | ||||
|  | ||||
| const aliasSet29 = ['lin-doc', 'lined-document'] as const; | ||||
|  | ||||
| const aliasSet30 = ['notch-pent', 'loop-limit', 'notched-pentagon'] as const; | ||||
|  | ||||
| const aliasSet31 = ['flip-tri', 'manual-file', 'flipped-triangle'] as const; | ||||
|  | ||||
| const aliasSet32 = ['sl-rect', 'manual-input', 'sloped-rectangle'] as const; | ||||
|  | ||||
| const aliasSet33 = ['docs', 'documents', 'st-doc', 'stacked-document'] as const; | ||||
|  | ||||
| const aliasSet34 = ['procs', 'processes', 'st-rect', 'stacked-rectangle'] as const; | ||||
|  | ||||
| const aliasSet35 = ['flag', 'paper-tape'] as const; | ||||
|  | ||||
| const aliasSet36 = ['bow-rect', 'stored-data', 'bow-tie-rectangle'] as const; | ||||
|  | ||||
| const aliasSet37 = ['cross-circ', 'summary', 'crossed-circle'] as const; | ||||
|  | ||||
| const aliasSet38 = ['tag-doc', 'tagged-document'] as const; | ||||
|  | ||||
| const aliasSet39 = ['tag-rect', 'tag-proc', 'tagged-rectangle', 'tagged-process'] as const; | ||||
|  | ||||
| const aliasSet40 = ['collate', 'hourglass'] as const; | ||||
|  | ||||
| // Aggregate all alias sets into a single array | ||||
| const aliasSets = [ | ||||
|   aliasSet1, | ||||
|   aliasSet2, | ||||
|   aliasSet3, | ||||
|   aliasSet4, | ||||
|   aliasSet5, | ||||
|   aliasSet6, | ||||
|   aliasSet7, | ||||
|   aliasSet8, | ||||
|   aliasSet9, | ||||
|   aliasSet10, | ||||
|   aliasSet11, | ||||
|   aliasSet12, | ||||
|   aliasSet13, | ||||
|   aliasSet14, | ||||
|   aliasSet15, | ||||
|   aliasSet16, | ||||
|   aliasSet17, | ||||
|   aliasSet18, | ||||
|   aliasSet19, | ||||
|   aliasSet20, | ||||
|   aliasSet21, | ||||
|   aliasSet22, | ||||
|   aliasSet23, | ||||
|   aliasSet24, | ||||
|   aliasSet25, | ||||
|   aliasSet26, | ||||
|   aliasSet27, | ||||
|   aliasSet28, | ||||
|   aliasSet29, | ||||
|   aliasSet30, | ||||
|   aliasSet31, | ||||
|   aliasSet32, | ||||
|   aliasSet33, | ||||
|   aliasSet34, | ||||
|   aliasSet35, | ||||
|   aliasSet36, | ||||
|   aliasSet37, | ||||
|   aliasSet38, | ||||
|   aliasSet39, | ||||
| ] as const; | ||||
|  | ||||
| aliasSets.forEach((aliasSet) => { | ||||
|   describe(`Test ${aliasSet.join(',')} `, () => { | ||||
|     it(`All ${aliasSet.join(',')} should render same shape`, () => { | ||||
|       let flowchartCode = `flowchart \n`; | ||||
|       aliasSet.forEach((alias, index) => { | ||||
|         flowchartCode += ` n${index}@{ shape: ${alias}, label: "${alias}" }\n`; | ||||
|       }); | ||||
|       imgSnapshotTest(flowchartCode); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
| @@ -99,7 +99,7 @@ describe('Flowchart v2', () => { | ||||
|       const style = svg.attr('style'); | ||||
|       expect(style).to.match(/^max-width: [\d.]+px;$/); | ||||
|       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join('')); | ||||
|       expect(maxWidthValue).to.be.within(290 * 0.95 - 1, 290 * 1.05); | ||||
|       expect(maxWidthValue).to.be.within(417 * 0.95, 417 * 1.05); | ||||
|     }); | ||||
|   }); | ||||
|   it('8: should render a flowchart when useMaxWidth is false', () => { | ||||
| @@ -118,7 +118,7 @@ describe('Flowchart v2', () => { | ||||
|       const width = parseFloat(svg.attr('width')); | ||||
|       // use within because the absolute value can be slightly different depending on the environment ±5% | ||||
|       // expect(height).to.be.within(446 * 0.95, 446 * 1.05); | ||||
|       expect(width).to.be.within(290 * 0.95 - 1, 290 * 1.05); | ||||
|       expect(width).to.be.within(417 * 0.95, 417 * 1.05); | ||||
|       expect(svg).to.not.have.attr('style'); | ||||
|     }); | ||||
|   }); | ||||
| @@ -786,7 +786,7 @@ A ~~~ B | ||||
|       `--- | ||||
|       title: Subgraph nodeSpacing and rankSpacing example | ||||
|       config: | ||||
|         flowchart:  | ||||
|         flowchart: | ||||
|           nodeSpacing: 250 | ||||
|           rankSpacing: 250 | ||||
|       --- | ||||
| @@ -1047,7 +1047,32 @@ end | ||||
|           A --lb3--> TOP --lb4--> B | ||||
|           B1 --lb5--> B2 | ||||
|         `, | ||||
|         { flowchart: { subGraphTitleMargin: { top: 10, bottom: 5 } } } | ||||
|         { | ||||
|           flowchart: { subGraphTitleMargin: { top: 10, bottom: 5 } }, | ||||
|         } | ||||
|       ); | ||||
|     }); | ||||
|     it('Should render self-loops', () => { | ||||
|       imgSnapshotTest( | ||||
|         `flowchart | ||||
|           A --> A | ||||
|           subgraph B | ||||
|             B1 --> B1 | ||||
|           end | ||||
|           subgraph C | ||||
|             subgraph C1 | ||||
|               C2 --> C2 | ||||
|               subgraph D | ||||
|                 D1 --> D1 | ||||
|               end | ||||
|               D --> D | ||||
|             end | ||||
|             C1 --> C1 | ||||
|           end | ||||
|         `, | ||||
|         { | ||||
|           flowchart: { subGraphTitleMargin: { top: 10, bottom: 5 } }, | ||||
|         } | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   | ||||
| @@ -733,7 +733,7 @@ describe('Graph', () => { | ||||
|   }); | ||||
|   it('38: should render a flowchart when useMaxWidth is true (default)', () => { | ||||
|     renderGraph( | ||||
|       `graph TD | ||||
|       `flowchart TD | ||||
|       A[Christmas] -->|Get money| B(Go shopping) | ||||
|       B --> C{Let me think} | ||||
|       C -->|One| D[Laptop] | ||||
| @@ -751,7 +751,7 @@ describe('Graph', () => { | ||||
|       const style = svg.attr('style'); | ||||
|       expect(style).to.match(/^max-width: [\d.]+px;$/); | ||||
|       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join('')); | ||||
|       expect(maxWidthValue).to.be.within(300 * 0.9, 300 * 1.1); | ||||
|       expect(maxWidthValue).to.be.within(446 * 0.9, 446 * 1.1); | ||||
|     }); | ||||
|   }); | ||||
|   it('39: should render a flowchart when useMaxWidth is false', () => { | ||||
| @@ -770,7 +770,7 @@ describe('Graph', () => { | ||||
|       const width = parseFloat(svg.attr('width')); | ||||
|       // use within because the absolute value can be slightly different depending on the environment ±10% | ||||
|       // expect(height).to.be.within(446 * 0.95, 446 * 1.05); | ||||
|       expect(width).to.be.within(300 * 0.9, 300 * 1.1); | ||||
|       expect(width).to.be.within(446 * 0.9, 446 * 1.1); | ||||
|       expect(svg).to.not.have.attr('style'); | ||||
|     }); | ||||
|   }); | ||||
| @@ -905,13 +905,16 @@ graph TD | ||||
|   it('67: should be able to style default node independently', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|     flowchart TD | ||||
|       flowchart TD | ||||
|       classDef default fill:#a34 | ||||
|       hello --> default | ||||
|  | ||||
|       style default stroke:#000,stroke-width:4px | ||||
|     `, | ||||
|       { htmlLabels: true, flowchart: { htmlLabels: true }, securityLevel: 'loose' } | ||||
|       { | ||||
|         flowchart: { htmlLabels: true }, | ||||
|         securityLevel: 'loose', | ||||
|       } | ||||
|     ); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
| @@ -1532,5 +1532,41 @@ gitGraph TB: | ||||
|         {} | ||||
|       ); | ||||
|     }); | ||||
|     it('75: should render a gitGraph with multiple tags on a merge commit on bottom-to-top orientation', () => { | ||||
|       imgSnapshotTest( | ||||
|         `gitGraph BT: | ||||
|         commit id: "ZERO" | ||||
|         branch develop | ||||
|         commit id:"A" | ||||
|         checkout main | ||||
|         commit id:"ONE" | ||||
|         checkout develop | ||||
|         commit id:"B" | ||||
|         checkout main | ||||
|         merge develop id:"Release 1.0" type:HIGHLIGHT tag: "SAML v2.0" tag: "OpenID v1.1" | ||||
|         commit id:"TWO" | ||||
|         checkout develop | ||||
|         commit id:"C"`, | ||||
|         {} | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   it('76: should render a gitGraph with multiple tags on a merge commit on left-to-right orientation', () => { | ||||
|     imgSnapshotTest( | ||||
|       `gitGraph | ||||
|     commit id: "ZERO" | ||||
|     branch develop | ||||
|     commit id:"A" | ||||
|     checkout main | ||||
|     commit id:"ONE" | ||||
|     checkout develop | ||||
|     commit id:"B" | ||||
|     checkout main | ||||
|     merge develop id:"Release 1.0" type:HIGHLIGHT tag: "SAML v2.0" tag: "OpenID v1.1" | ||||
|     commit id:"TWO" | ||||
|     checkout develop | ||||
|     commit id:"C"`, | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
							
								
								
									
										126
									
								
								cypress/integration/rendering/iconShape.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								cypress/integration/rendering/iconShape.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| import { imgSnapshotTest } from '../../helpers/util'; | ||||
|  | ||||
| const looks = ['classic', 'handDrawn'] as const; | ||||
| const directions = [ | ||||
|   'TB', | ||||
|   //'BT', | ||||
|   'LR', | ||||
|   //  'RL' | ||||
| ] as const; | ||||
| const forms = [undefined, 'square', 'circle', 'rounded'] as const; | ||||
| const labelPos = [undefined, 't', 'b'] as const; | ||||
|  | ||||
| looks.forEach((look) => { | ||||
|   directions.forEach((direction) => { | ||||
|     forms.forEach((form) => { | ||||
|       labelPos.forEach((pos) => { | ||||
|         describe(`Test iconShape in ${form ? `${form} form,` : ''} ${look} look and dir ${direction} with label position ${pos ? pos : 'not defined'}`, () => { | ||||
|           it(`without label`, () => { | ||||
|             let flowchartCode = `flowchart ${direction}\n`; | ||||
|             flowchartCode += `  nA --> nAA@{ icon: 'fa:bell'`; | ||||
|             if (form) { | ||||
|               flowchartCode += `, form: '${form}'`; | ||||
|             } | ||||
|             flowchartCode += ` }\n`; | ||||
|             imgSnapshotTest(flowchartCode, { look }); | ||||
|           }); | ||||
|  | ||||
|           it(`with label`, () => { | ||||
|             let flowchartCode = `flowchart ${direction}\n`; | ||||
|             flowchartCode += `  nA --> nAA@{ icon: 'fa:bell', label: 'This is a label for icon shape'`; | ||||
|             if (form) { | ||||
|               flowchartCode += `, form: '${form}'`; | ||||
|             } | ||||
|             if (pos) { | ||||
|               flowchartCode += `, pos: '${pos}'`; | ||||
|             } | ||||
|             flowchartCode += ` }\n`; | ||||
|             imgSnapshotTest(flowchartCode, { look }); | ||||
|           }); | ||||
|  | ||||
|           it(`with very long label`, () => { | ||||
|             let flowchartCode = `flowchart ${direction}\n`; | ||||
|             flowchartCode += `  nA --> nAA@{ icon: 'fa:bell', label: 'This is a very very very very very long long long label for icon shape'`; | ||||
|             if (form) { | ||||
|               flowchartCode += `, form: '${form}'`; | ||||
|             } | ||||
|             if (pos) { | ||||
|               flowchartCode += `, pos: '${pos}'`; | ||||
|             } | ||||
|             flowchartCode += ` }\n`; | ||||
|             imgSnapshotTest(flowchartCode, { look }); | ||||
|           }); | ||||
|  | ||||
|           it(`with markdown htmlLabels:true`, () => { | ||||
|             let flowchartCode = `flowchart ${direction}\n`; | ||||
|             flowchartCode += `  nA --> nAA@{ icon: 'fa:bell', label: 'This is **bold** </br>and <strong>strong</strong> for icon shape'`; | ||||
|             if (form) { | ||||
|               flowchartCode += `, form: '${form}'`; | ||||
|             } | ||||
|             if (pos) { | ||||
|               flowchartCode += `, pos: '${pos}'`; | ||||
|             } | ||||
|             flowchartCode += ` }\n`; | ||||
|             imgSnapshotTest(flowchartCode, { look }); | ||||
|           }); | ||||
|  | ||||
|           it(`with markdown htmlLabels:false`, () => { | ||||
|             let flowchartCode = `flowchart ${direction}\n`; | ||||
|             flowchartCode += `  nA --> nAA@{ icon: 'fa:bell', label: 'This is **bold** </br>and <strong>strong</strong> for icon shape'`; | ||||
|             if (form) { | ||||
|               flowchartCode += `, form: '${form}'`; | ||||
|             } | ||||
|             if (pos) { | ||||
|               flowchartCode += `, pos: '${pos}'`; | ||||
|             } | ||||
|             flowchartCode += ` }\n`; | ||||
|             imgSnapshotTest(flowchartCode, { | ||||
|               look, | ||||
|               htmlLabels: false, | ||||
|               flowchart: { htmlLabels: false }, | ||||
|             }); | ||||
|           }); | ||||
|  | ||||
|           it(`with styles`, () => { | ||||
|             let flowchartCode = `flowchart ${direction}\n`; | ||||
|             flowchartCode += `  nA --> nAA@{ icon: 'fa:bell', label: 'new icon shape'`; | ||||
|             if (form) { | ||||
|               flowchartCode += `, form: '${form}'`; | ||||
|             } | ||||
|             if (pos) { | ||||
|               flowchartCode += `, pos: '${pos}'`; | ||||
|             } | ||||
|             flowchartCode += ` }\n`; | ||||
|             flowchartCode += `  style nAA fill:#f9f,stroke:#333,stroke-width:4px \n`; | ||||
|             imgSnapshotTest(flowchartCode, { look }); | ||||
|           }); | ||||
|  | ||||
|           it(`with classDef`, () => { | ||||
|             let flowchartCode = `flowchart ${direction}\n`; | ||||
|             flowchartCode += `  classDef customClazz fill:#bbf,stroke:#f66,stroke-width:2px,color:#fff,stroke-dasharray: 5 5\n`; | ||||
|             flowchartCode += `  nA --> nAA@{ icon: 'fa:bell', label: 'new icon shape'`; | ||||
|             if (form) { | ||||
|               flowchartCode += `, form: '${form}'`; | ||||
|             } | ||||
|             if (pos) { | ||||
|               flowchartCode += `, pos: '${pos}'`; | ||||
|             } | ||||
|             flowchartCode += ` }\n`; | ||||
|             flowchartCode += `  nAA:::customClazz\n`; | ||||
|             imgSnapshotTest(flowchartCode, { look }); | ||||
|           }); | ||||
|         }); | ||||
|       }); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| describe('Test iconShape with different h', () => { | ||||
|   it('with different h', () => { | ||||
|     let flowchartCode = `flowchart TB\n`; | ||||
|     const icon = 'fa:bell'; | ||||
|     const iconHeight = 64; | ||||
|     flowchartCode += `  nA --> nAA@{ icon: '${icon}', label: 'icon with different h', h: ${iconHeight} }\n`; | ||||
|     imgSnapshotTest(flowchartCode); | ||||
|   }); | ||||
| }); | ||||
							
								
								
									
										103
									
								
								cypress/integration/rendering/imageShape.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								cypress/integration/rendering/imageShape.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | ||||
| import { imgSnapshotTest } from '../../helpers/util'; | ||||
|  | ||||
| const looks = ['classic', 'handDrawn'] as const; | ||||
| const directions = [ | ||||
|   'TB', | ||||
|   //'BT', | ||||
|   'LR', | ||||
|   //  'RL' | ||||
| ] as const; | ||||
| const labelPos = [undefined, 't', 'b'] as const; | ||||
|  | ||||
| looks.forEach((look) => { | ||||
|   directions.forEach((direction) => { | ||||
|     labelPos.forEach((pos) => { | ||||
|       describe(`Test imageShape in ${look} look and dir ${direction} with label position ${pos ? pos : 'not defined'}`, () => { | ||||
|         it(`without label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  nA --> A@{ img: 'https://cdn.pixabay.com/photo/2020/02/22/18/49/paper-4871356_1280.jpg', w: '100', h: '100' }\n`; | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  nA --> A@{ img: 'https://cdn.pixabay.com/photo/2020/02/22/18/49/paper-4871356_1280.jpg', label: 'This is a label for image shape'`; | ||||
|  | ||||
|           flowchartCode += `, w: '100', h: '200'`; | ||||
|           if (pos) { | ||||
|             flowchartCode += `, pos: '${pos}'`; | ||||
|           } | ||||
|           flowchartCode += ` }\n`; | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with very long label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  nA --> A@{ img: 'https://cdn.pixabay.com/photo/2020/02/22/18/49/paper-4871356_1280.jpg', label: 'This is a very very very very very long long long label for image shape'`; | ||||
|  | ||||
|           flowchartCode += `, w: '100', h: '250'`; | ||||
|           if (pos) { | ||||
|             flowchartCode += `, pos: '${pos}'`; | ||||
|           } | ||||
|           flowchartCode += ` }\n`; | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with markdown htmlLabels:true`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  nA --> A@{ img: 'https://cdn.pixabay.com/photo/2020/02/22/18/49/paper-4871356_1280.jpg', label: 'This is **bold** </br>and <strong>strong</strong> for image shape'`; | ||||
|  | ||||
|           flowchartCode += `, w: '550', h: '200'`; | ||||
|           if (pos) { | ||||
|             flowchartCode += `, pos: '${pos}'`; | ||||
|           } | ||||
|           flowchartCode += ` }\n`; | ||||
|           imgSnapshotTest(flowchartCode, { look, htmlLabels: true }); | ||||
|         }); | ||||
|  | ||||
|         it(`with markdown htmlLabels:false`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  nA --> A@{ img: 'https://cdn.pixabay.com/photo/2020/02/22/18/49/paper-4871356_1280.jpg', label: 'This is **bold** </br>and <strong>strong</strong> for image shape'`; | ||||
|           flowchartCode += `, w: '250', h: '200'`; | ||||
|  | ||||
|           if (pos) { | ||||
|             flowchartCode += `, pos: '${pos}'`; | ||||
|           } | ||||
|           flowchartCode += ` }\n`; | ||||
|           imgSnapshotTest(flowchartCode, { | ||||
|             look, | ||||
|             htmlLabels: false, | ||||
|             flowchart: { htmlLabels: false }, | ||||
|           }); | ||||
|         }); | ||||
|  | ||||
|         it(`with styles`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  nA --> A@{ img: 'https://cdn.pixabay.com/photo/2020/02/22/18/49/paper-4871356_1280.jpg', label: 'new image shape'`; | ||||
|           flowchartCode += `, w: '550', h: '200'`; | ||||
|  | ||||
|           if (pos) { | ||||
|             flowchartCode += `, pos: '${pos}'`; | ||||
|           } | ||||
|           flowchartCode += ` }\n`; | ||||
|           flowchartCode += `  style A fill:#f9f,stroke:#333,stroke-width:4px \n`; | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with classDef`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  classDef customClazz fill:#bbf,stroke:#f66,stroke-width:2px,color:#000000,stroke-dasharray: 5 5\n`; | ||||
|           flowchartCode += `  nA --> A@{ img: 'https://cdn.pixabay.com/photo/2020/02/22/18/49/paper-4871356_1280.jpg', label: 'new image shape'`; | ||||
|  | ||||
|           flowchartCode += `, w: '500', h: '550'`; | ||||
|           if (pos) { | ||||
|             flowchartCode += `, pos: '${pos}'`; | ||||
|           } | ||||
|           flowchartCode += ` }\n`; | ||||
|           flowchartCode += `  A:::customClazz\n`; | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|       }); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
							
								
								
									
										146
									
								
								cypress/integration/rendering/newShapes.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								cypress/integration/rendering/newShapes.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| import { imgSnapshotTest } from '../../helpers/util.ts'; | ||||
|  | ||||
| const looks = ['classic', 'handDrawn'] as const; | ||||
| const directions = [ | ||||
|   'TB', | ||||
|   //'BT', | ||||
|   'LR', | ||||
|   //'RL' | ||||
| ] as const; | ||||
| const newShapesSet1 = [ | ||||
|   'triangle', | ||||
|   'sloped-rectangle', | ||||
|   'horizontal-cylinder', | ||||
|   'flipped-triangle', | ||||
|   'hourglass', | ||||
| ] as const; | ||||
| const newShapesSet2 = [ | ||||
|   'tagged-rectangle', | ||||
|   'documents', | ||||
|   'lightning-bolt', | ||||
|   'filled-circle', | ||||
|   'window-pane', | ||||
| ] as const; | ||||
|  | ||||
| const newShapesSet3 = [ | ||||
|   'curved-trapezoid', | ||||
|   'bow-rect', | ||||
|   'tagged-document', | ||||
|   'divided-rectangle', | ||||
|   'crossed-circle', | ||||
| ] as const; | ||||
|  | ||||
| const newShapesSet4 = [ | ||||
|   'document', | ||||
|   'notched-pentagon', | ||||
|   'lined-cylinder', | ||||
|   'stacked-document', | ||||
|   'half-rounded-rectangle', | ||||
| ] as const; | ||||
|  | ||||
| const newShapesSet5 = [ | ||||
|   'lined-document', | ||||
|   'tagged-document', | ||||
|   'brace-l', | ||||
|   'comment', | ||||
|   'braces', | ||||
|   'brace-r', | ||||
| ] as const; | ||||
|  | ||||
| const newShapesSet6 = ['brace-r', 'braces'] as const; | ||||
| // Aggregate all shape sets into a single array | ||||
| const newShapesSets = [ | ||||
|   newShapesSet1, | ||||
|   newShapesSet2, | ||||
|   newShapesSet3, | ||||
|   newShapesSet4, | ||||
|   newShapesSet5, | ||||
|   newShapesSet6, | ||||
| ]; | ||||
|  | ||||
| looks.forEach((look) => { | ||||
|   directions.forEach((direction) => { | ||||
|     newShapesSets.forEach((newShapesSet) => { | ||||
|       describe(`Test ${newShapesSet.join(', ')} in ${look} look and dir ${direction}`, () => { | ||||
|         it(`without label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape} }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is a label for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`connect all shapes with each other`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index}${index}@{ shape: ${newShape}, label: 'This is a label for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           for (let i = 0; i < newShapesSet.length; i++) { | ||||
|             for (let j = i + 1; j < newShapesSet.length; j++) { | ||||
|               flowchartCode += `  n${i}${i} --> n${j}${j}\n`; | ||||
|             } | ||||
|           } | ||||
|           if (!(direction === 'TB' && look === 'handDrawn' && newShapesSet === newShapesSet1)) { | ||||
|             //skip this test, works in real. Need to look | ||||
|             imgSnapshotTest(flowchartCode, { look }); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         it(`with very long label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is a very very very very very long long long label for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with markdown htmlLabels:true`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is **bold** </br>and <strong>strong</strong> for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with markdown htmlLabels:false`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is **bold** </br>and <strong>strong</strong> for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { | ||||
|             look, | ||||
|             htmlLabels: false, | ||||
|             flowchart: { htmlLabels: false }, | ||||
|           }); | ||||
|         }); | ||||
|  | ||||
|         it(`with styles`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'new ${newShape} shape' }\n`; | ||||
|             flowchartCode += `  style n${index}${index} fill:#f9f,stroke:#333,stroke-width:4px \n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with classDef`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  classDef customClazz fill:#bbf,stroke:#f66,stroke-width:2px,color:#fff,stroke-dasharray: 5 5\n`; | ||||
|           newShapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'new ${newShape} shape' }\n`; | ||||
|             flowchartCode += `  n${index}${index}:::customClazz\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|       }); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
							
								
								
									
										107
									
								
								cypress/integration/rendering/oldShapes.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								cypress/integration/rendering/oldShapes.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| import { imgSnapshotTest } from '../../helpers/util'; | ||||
|  | ||||
| const looks = ['classic', 'handDrawn'] as const; | ||||
| const directions = [ | ||||
|   'TB', | ||||
|   //'BT', | ||||
|   'LR', | ||||
|   //'RL' | ||||
| ] as const; | ||||
|  | ||||
| const shapesSet1 = ['text', 'card', 'lin-rect', 'diamond', 'hexagon'] as const; | ||||
|  | ||||
| // removing labelRect, need have alias for it | ||||
| const shapesSet2 = ['rounded', 'rect', 'start', 'stop'] as const; | ||||
|  | ||||
| const shapesSet3 = ['fork', 'choice', 'note', 'stadium', 'odd'] as const; | ||||
|  | ||||
| const shapesSet4 = ['subroutine', 'cylinder', 'circle', 'doublecircle', 'odd'] as const; | ||||
|  | ||||
| const shapesSet5 = ['anchor', 'lean-r', 'lean-l', 'trap-t', 'trap-b'] as const; | ||||
|  | ||||
| // Aggregate all shape sets into a single array | ||||
| const shapesSets = [shapesSet1, shapesSet2, shapesSet3, shapesSet4, shapesSet5] as const; | ||||
|  | ||||
| looks.forEach((look) => { | ||||
|   directions.forEach((direction) => { | ||||
|     shapesSets.forEach((shapesSet) => { | ||||
|       describe(`Test ${shapesSet.join(', ')} in ${look} look and dir ${direction}`, () => { | ||||
|         it(`without label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape} }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is a label for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`connect all shapes with each other`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index}${index}@{ shape: ${newShape}, label: 'This is a label for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           for (let i = 0; i < shapesSet.length; i++) { | ||||
|             for (let j = i + 1; j < shapesSet.length; j++) { | ||||
|               flowchartCode += `  n${i}${i} --> n${j}${j}\n`; | ||||
|             } | ||||
|           } | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with very long label`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is a very very very very very long long long label for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with markdown htmlLabels:true`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is **bold** </br>and <strong>strong</strong> for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with markdown htmlLabels:false`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'This is **bold** </br>and <strong>strong</strong> for ${newShape} shape' }\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { | ||||
|             look, | ||||
|             htmlLabels: false, | ||||
|             flowchart: { htmlLabels: false }, | ||||
|           }); | ||||
|         }); | ||||
|  | ||||
|         it(`with styles`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'new ${newShape} shape' }\n`; | ||||
|             flowchartCode += `  style n${index}${index} fill:#f9f,stroke:#333,stroke-width:4px \n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|  | ||||
|         it(`with classDef`, () => { | ||||
|           let flowchartCode = `flowchart ${direction}\n`; | ||||
|           flowchartCode += `  classDef customClazz fill:#bbf,stroke:#f66,stroke-width:2px,color:#fff,stroke-dasharray: 5 5\n`; | ||||
|           shapesSet.forEach((newShape, index) => { | ||||
|             flowchartCode += `  n${index} --> n${index}${index}@{ shape: ${newShape}, label: 'new ${newShape} shape' }\n`; | ||||
|             flowchartCode += `  n${index}${index}:::customClazz\n`; | ||||
|           }); | ||||
|           imgSnapshotTest(flowchartCode, { look }); | ||||
|         }); | ||||
|       }); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
| @@ -10,6 +10,15 @@ describe('packet structure', () => { | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('should render a simple packet diagram without ranges', () => { | ||||
|     imgSnapshotTest( | ||||
|       `packet-beta | ||||
|   0: "h" | ||||
|   1: "i" | ||||
| ` | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it('should render a complex packet diagram', () => { | ||||
|     imgSnapshotTest( | ||||
|       `packet-beta | ||||
|   | ||||
| @@ -8,7 +8,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a complete quadrant chart', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -30,7 +29,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render without points', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -46,7 +44,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should able to render y-axix on right side', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -63,7 +60,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should able to render x-axix on bottom', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -80,7 +76,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should able to render x-axix on bottom and y-axis on right', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -97,7 +92,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render without title', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -112,7 +106,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should use all the config', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -135,7 +128,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should use all the theme variable', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -158,7 +150,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render x-axis labels in the center, if x-axis has two labels', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -180,7 +171,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render y-axis labels in the center, if y-axis has two labels', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -202,7 +192,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render both axes labels on the left and bottom, if both axes have only one label', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -224,7 +213,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('it should render data points with styles', () => { | ||||
| @@ -249,7 +237,6 @@ describe('Quadrant Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|  | ||||
|   it('it should render data points with styles + classes', () => { | ||||
|   | ||||
| @@ -44,6 +44,5 @@ describe('Requirement diagram', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
| @@ -1,8 +1,6 @@ | ||||
| /// <reference types="Cypress" /> | ||||
|  | ||||
| import { imgSnapshotTest, renderGraph } from '../../helpers/util.ts'; | ||||
|  | ||||
| context('Sequence diagram', () => { | ||||
| describe('Sequence diagram', () => { | ||||
|   it('should render a sequence diagram with boxes', () => { | ||||
|     renderGraph( | ||||
|       ` | ||||
| @@ -68,6 +66,19 @@ context('Sequence diagram', () => { | ||||
|       { sequence: { actorFontFamily: 'courier' } } | ||||
|     ); | ||||
|   }); | ||||
|   it('should render bidirectional arrows', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|       sequenceDiagram | ||||
|       Alice<<->>John: Hello John, how are you? | ||||
|       Alice<<-->>John: Hi Alice, I can hear you! | ||||
|       John<<->>Alice: This also works the other way | ||||
|       John<<-->>Alice: Yes | ||||
|       Alice->John: Test | ||||
|       John->>Alice: Still works | ||||
|       ` | ||||
|     ); | ||||
|   }); | ||||
|   it('should handle different line breaks', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
| @@ -231,7 +242,7 @@ context('Sequence diagram', () => { | ||||
|       ` | ||||
|     ); | ||||
|   }); | ||||
|   context('font settings', () => { | ||||
|   describe('font settings', () => { | ||||
|     it('should render different note fonts when configured', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
| @@ -328,7 +339,7 @@ context('Sequence diagram', () => { | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   context('auth width scaling', () => { | ||||
|   describe('auth width scaling', () => { | ||||
|     it('should render long actor descriptions', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
| @@ -464,6 +475,18 @@ context('Sequence diagram', () => { | ||||
|         {} | ||||
|       ); | ||||
|     }); | ||||
|     it('should render notes over actors and participant', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
|         sequenceDiagram | ||||
|         actor Alice | ||||
|         participant Charlie | ||||
|         note over Alice: some note | ||||
|         note over Charlie: other note | ||||
|       `, | ||||
|         {} | ||||
|       ); | ||||
|     }); | ||||
|     it('should render long messages from an actor to the left to one to the right', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
| @@ -505,7 +528,7 @@ context('Sequence diagram', () => { | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   context('background rects', () => { | ||||
|   describe('background rects', () => { | ||||
|     it('should render a single and nested rects', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
| @@ -785,7 +808,7 @@ context('Sequence diagram', () => { | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   context('directives', () => { | ||||
|   describe('directives', () => { | ||||
|     it('should override config with directive settings', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
| @@ -817,7 +840,7 @@ context('Sequence diagram', () => { | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   context('links', () => { | ||||
|   describe('links', () => { | ||||
|     it('should support actor links', () => { | ||||
|       renderGraph( | ||||
|         ` | ||||
| @@ -833,7 +856,7 @@ context('Sequence diagram', () => { | ||||
|       ); | ||||
|       cy.get('#actor0_popup').should((popupMenu) => { | ||||
|         const style = popupMenu.attr('style'); | ||||
|         expect(style).to.undefined; | ||||
|         // expect(style).to.undefined; | ||||
|       }); | ||||
|       cy.get('#root-0').click(); | ||||
|       cy.get('#actor0_popup').should((popupMenu) => { | ||||
| @@ -908,7 +931,7 @@ context('Sequence diagram', () => { | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   context('svg size', () => { | ||||
|   describe('svg size', () => { | ||||
|     it('should render a sequence diagram when useMaxWidth is true (default)', () => { | ||||
|       renderGraph( | ||||
|         ` | ||||
| @@ -987,7 +1010,7 @@ context('Sequence diagram', () => { | ||||
|       }); | ||||
|     }); | ||||
|   }); | ||||
|   context('render after error', () => { | ||||
|   describe('render after error', () => { | ||||
|     it('should render diagram after fixing destroy participant error', () => { | ||||
|       cy.on('uncaught:exception', (err) => { | ||||
|         return false; | ||||
|   | ||||
| @@ -8,7 +8,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 1, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a simple state diagrams', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -20,7 +19,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a long descriptions instead of id when available', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -32,7 +30,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a long descriptions with additional descriptions', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -44,7 +41,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a single state with short descriptions', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -55,7 +51,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a transition descriptions with new lines', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -69,7 +64,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a state with a note', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -83,7 +77,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a state with on the left side when so specified', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -97,7 +90,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a state with a note together with another state', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -113,7 +105,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a note with multiple lines in it', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -156,7 +147,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a simple state diagrams 2', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -169,7 +159,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a simple state diagrams with labels', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -185,7 +174,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render state descriptions', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -198,7 +186,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render composite states', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -217,7 +204,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render multiple composite states', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -287,7 +273,6 @@ describe('State diagram', () => { | ||||
|     `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render concurrency states', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -311,7 +296,6 @@ describe('State diagram', () => { | ||||
|     `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('v2 should render a state with states in it', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -558,6 +542,43 @@ stateDiagram-v2 | ||||
|         { logLevel: 0, fontFamily: 'courier' } | ||||
|       ); | ||||
|     }); | ||||
|     it(' can have styles applied ', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
| stateDiagram-v2 | ||||
| AState | ||||
| style AState fill:#636,border:1px solid red,color:white; | ||||
|         `, | ||||
|         { logLevel: 0, fontFamily: 'courier' } | ||||
|       ); | ||||
|     }); | ||||
|     it(' should let styles take preceedence over classes', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
| stateDiagram-v2 | ||||
| AState: Should NOT be white | ||||
| BState | ||||
| classDef exampleStyleClass fill:#fff,color: blue; | ||||
| class AState,BState exampleStyleClass | ||||
| style AState fill:#636,border:1px solid red,color:white; | ||||
|         `, | ||||
|         { logLevel: 0, fontFamily: 'courier' } | ||||
|       ); | ||||
|     }); | ||||
|     it(' should allow styles to take effect in stubgraphs', () => { | ||||
|       imgSnapshotTest( | ||||
|         ` | ||||
|   stateDiagram | ||||
|     state roundWithTitle { | ||||
|       C: Black with white text | ||||
|     } | ||||
|     D: Black with white text | ||||
|  | ||||
|     style C,D stroke:#00f, fill:black, color:white | ||||
|         `, | ||||
|         { logLevel: 0, fontFamily: 'courier' } | ||||
|       ); | ||||
|     }); | ||||
|   }); | ||||
|   it('1433: should render a simple state diagram with a title', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -567,6 +588,20 @@ title: simple state diagram | ||||
| stateDiagram-v2 | ||||
| [*] --> State1 | ||||
| State1 --> [*] | ||||
| `, | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   it('should align dividers correctly', () => { | ||||
|     imgSnapshotTest( | ||||
|       `stateDiagram-v2 | ||||
|   state s2 { | ||||
|       s3 | ||||
|       -- | ||||
|       s4 | ||||
|       -- | ||||
|       55 | ||||
|   } | ||||
| `, | ||||
|       {} | ||||
|     ); | ||||
|   | ||||
| @@ -10,7 +10,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a long descriptions instead of id when available', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -22,7 +21,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a long descriptions with additional descriptions', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -34,7 +32,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a single state with short descriptions', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -45,7 +42,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a transition descriptions with new lines', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -59,7 +55,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a state with a note', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -73,7 +68,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a state with on the left side when so specified', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -87,7 +81,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a state with a note together with another state', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -103,7 +96,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a note with multiple lines in it', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -146,7 +138,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a simple state diagrams 2', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -159,7 +150,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a simple state diagrams with labels', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -175,7 +165,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render state descriptions', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -188,7 +177,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render composite states', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -207,7 +195,6 @@ describe('State diagram', () => { | ||||
|       `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render multiple composit states', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -277,7 +264,6 @@ describe('State diagram', () => { | ||||
|     `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render concurrency states', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -301,7 +287,6 @@ describe('State diagram', () => { | ||||
|     `, | ||||
|       { logLevel: 0, fontFamily: 'courier' } | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should render a state with states in it', () => { | ||||
|     imgSnapshotTest( | ||||
|   | ||||
| @@ -10,7 +10,6 @@ describe('themeCSS balancing, it', () => { | ||||
|           `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('should not allow unbalanced CSS definitions 2', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -21,7 +20,6 @@ describe('themeCSS balancing, it', () => { | ||||
|           `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
| }); | ||||
|  | ||||
| @@ -45,7 +43,6 @@ describe('Pie Chart', () => { | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a flowchart diagram', () => { | ||||
|         imgSnapshotTest( | ||||
| @@ -70,7 +67,6 @@ describe('Pie Chart', () => { | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a new flowchart diagram', () => { | ||||
|         imgSnapshotTest( | ||||
| @@ -96,7 +92,6 @@ describe('Pie Chart', () => { | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a sequence diagram', () => { | ||||
|         imgSnapshotTest( | ||||
| @@ -125,7 +120,6 @@ describe('Pie Chart', () => { | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|  | ||||
|       it('should render a class diagram', () => { | ||||
| @@ -175,7 +169,6 @@ describe('Pie Chart', () => { | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a state diagram', () => { | ||||
|         imgSnapshotTest( | ||||
| @@ -210,7 +203,6 @@ stateDiagram | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a state diagram (v2)', () => { | ||||
|         imgSnapshotTest( | ||||
| @@ -245,7 +237,6 @@ stateDiagram-v2 | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a er diagram', () => { | ||||
|         imgSnapshotTest( | ||||
| @@ -266,7 +257,6 @@ erDiagram | ||||
|           `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a user journey diagram', () => { | ||||
|         imgSnapshotTest( | ||||
| @@ -287,7 +277,6 @@ erDiagram | ||||
|                         `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|       it('should render a gantt diagram', () => { | ||||
|         cy.clock(new Date('2014-01-06').getTime()); | ||||
| @@ -326,7 +315,6 @@ erDiagram | ||||
|        `, | ||||
|           { theme } | ||||
|         ); | ||||
|         cy.get('svg'); | ||||
|       }); | ||||
|     }); | ||||
|   }); | ||||
|   | ||||
| @@ -9,7 +9,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Should render a complete chart', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -35,7 +34,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('y-axis title not required', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -48,7 +46,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Should render a chart without y-axis with different range', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -60,7 +57,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('x axis title not required', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -72,7 +68,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Multiple plots can be rendered', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -87,7 +82,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Decimals and negative numbers are supported', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -98,7 +92,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Render spark line with "plotReservedSpacePercent"', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -116,7 +109,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Render spark bar without displaying other property', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -143,7 +135,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Should use all the config from directive', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -158,7 +149,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Should use all the config from yaml', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -199,7 +189,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Render with show axis title false', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -221,7 +210,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Render with show axis label false', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -243,7 +231,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Render with show axis tick false', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -265,7 +252,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Render with show axis line false', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -287,7 +273,6 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
|   it('Render all the theme color', () => { | ||||
|     imgSnapshotTest( | ||||
| @@ -317,6 +302,17 @@ describe('XY Chart', () => { | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|   }); | ||||
|   it('should use the correct distances between data points', () => { | ||||
|     imgSnapshotTest( | ||||
|       ` | ||||
|       xychart-beta | ||||
|         x-axis 0 --> 2 | ||||
|         line [0, 1, 0, 1] | ||||
|         bar [1, 0, 1, 0] | ||||
|       `, | ||||
|       {} | ||||
|     ); | ||||
|     cy.get('svg'); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
							
								
								
									
										52
									
								
								cypress/platform/architecture-external.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								cypress/platform/architecture-external.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | ||||
| <!doctype html> | ||||
| <html lang="en"> | ||||
|   <head> | ||||
|     <meta charset="utf-8" /> | ||||
|     <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | ||||
|     <title>Architecture Mermaid Test Page</title> | ||||
|     <link rel="icon" type="image/png" href="data:image/png;base64,iVBORw0KGgo=" /> | ||||
|     <style> | ||||
|       div.mermaid { | ||||
|         /* font-family: 'trebuchet ms', verdana, arial; */ | ||||
|         font-family: 'Courier New', Courier, monospace !important; | ||||
|       } | ||||
|     </style> | ||||
|   </head> | ||||
|  | ||||
|   <body> | ||||
|     <h2>External Icons Demo</h2> | ||||
|     <pre class="mermaid"> | ||||
|     architecture-beta | ||||
|       service s3(logos:aws-s3)[Cloud Store] | ||||
|       service ec2(logos:aws-ec2)[Server] | ||||
|       service api(logos:aws-api-gateway)[Api Gateway] | ||||
|       service fa(fa:image)[Font Awesome Icon] | ||||
|     </pre> | ||||
|  | ||||
|     <script type="module"> | ||||
|       import mermaid from './mermaid.esm.mjs'; | ||||
|       mermaid.initialize({ | ||||
|         startOnLoad: false, | ||||
|         logLevel: 0, | ||||
|       }); | ||||
|       mermaid.registerIconPacks([ | ||||
|         { | ||||
|           name: 'logos', | ||||
|           loader: () => | ||||
|             fetch('https://unpkg.com/@iconify-json/logos/icons.json').then((res) => res.json()), | ||||
|         }, | ||||
|         { | ||||
|           name: 'fa', | ||||
|           loader: () => | ||||
|             fetch('https://unpkg.com/@iconify-json/fa6-regular/icons.json').then((res) => | ||||
|               res.json() | ||||
|             ), | ||||
|         }, | ||||
|       ]); | ||||
|       await mermaid.run(); | ||||
|       if (window.Cypress) { | ||||
|         window.rendered = true; | ||||
|       } | ||||
|     </script> | ||||
|   </body> | ||||
| </html> | ||||
| @@ -27,7 +27,7 @@ const code3 = `flowchart TD | ||||
| A(<img scr='https://iconscout.com/ms-icon-310x310.png' width='20' height='20' />) | ||||
| B(<b>Bold text!</b>)`; | ||||
|  | ||||
| if (location.href.match('test-html-escaping')) { | ||||
| if (/test-html-escaping/.exec(location.href)) { | ||||
|   code = code3; | ||||
| } | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,181 +1,191 @@ | ||||
| <html> | ||||
|   <head> | ||||
|     <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" /> | ||||
|     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> | ||||
|     <link | ||||
|       rel="stylesheet" | ||||
|       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://cdn.jsdelivr.net/npm/@mdi/font@6.9.96/css/materialdesignicons.min.css" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link rel="preconnect" href="https://fonts.googleapis.com" /> | ||||
|     <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&family=Kalam:wght@300;400;700&family=Rubik+Mono+One&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&family=Rubik+Mono+One&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|  | ||||
| <head> | ||||
|   <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" /> | ||||
|   <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> | ||||
|   <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" /> | ||||
|   <link href="https://cdn.jsdelivr.net/npm/@mdi/font@6.9.96/css/materialdesignicons.min.css" rel="stylesheet" /> | ||||
|   <link href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap" rel="stylesheet" /> | ||||
|   <link rel="preconnect" href="https://fonts.googleapis.com" /> | ||||
|   <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin /> | ||||
|   <link href="https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&display=swap" rel="stylesheet" /> | ||||
|   <link | ||||
|     href="https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&family=Kalam:wght@300;400;700&family=Rubik+Mono+One&display=swap" | ||||
|     rel="stylesheet" /> | ||||
|   <link href="https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&family=Rubik+Mono+One&display=swap" | ||||
|     rel="stylesheet" /> | ||||
|     <style> | ||||
|       body { | ||||
|         font-family: 'Arial'; | ||||
|       } | ||||
|  | ||||
|   <style> | ||||
|     body { | ||||
|       font-family: 'Arial'; | ||||
|     } | ||||
|       table { | ||||
|         width: 100%; | ||||
|         border-collapse: collapse; | ||||
|         table-layout: fixed; | ||||
|       } | ||||
|  | ||||
|     table { | ||||
|       width: 100%; | ||||
|       border-collapse: collapse; | ||||
|       table-layout: fixed; | ||||
|     } | ||||
|       th, | ||||
|       td { | ||||
|         border: 1px solid black; | ||||
|         padding: 10px; | ||||
|         text-align: center; | ||||
|         vertical-align: middle; | ||||
|       } | ||||
|  | ||||
|     th, | ||||
|     td { | ||||
|       border: 1px solid black; | ||||
|       padding: 10px; | ||||
|       text-align: center; | ||||
|       vertical-align: middle; | ||||
|     } | ||||
|       .separator { | ||||
|         height: 20px; | ||||
|         background-color: #f0f0f0; | ||||
|       } | ||||
|  | ||||
|     .separator { | ||||
|       height: 20px; | ||||
|       background-color: #f0f0f0; | ||||
|     } | ||||
|       .vertical-header { | ||||
|         text-align: center; | ||||
|       } | ||||
|  | ||||
|     .vertical-header { | ||||
|       text-align: center; | ||||
|     } | ||||
|       .collapsible { | ||||
|         background-color: #f9f9f9; | ||||
|         color: #444; | ||||
|         cursor: pointer; | ||||
|         padding: 18px; | ||||
|         width: 100%; | ||||
|         border: none; | ||||
|         text-align: left; | ||||
|         outline: none; | ||||
|         font-size: 15px; | ||||
|       } | ||||
|  | ||||
|     .collapsible { | ||||
|       background-color: #f9f9f9; | ||||
|       color: #444; | ||||
|       cursor: pointer; | ||||
|       padding: 18px; | ||||
|       width: 100%; | ||||
|       border: none; | ||||
|       text-align: left; | ||||
|       outline: none; | ||||
|       font-size: 15px; | ||||
|     } | ||||
|       .active, | ||||
|       .collapsible:hover { | ||||
|         background-color: #ccc; | ||||
|       } | ||||
|  | ||||
|     .active, | ||||
|     .collapsible:hover { | ||||
|       background-color: #ccc; | ||||
|     } | ||||
|       .collapsible:after { | ||||
|         content: '\002B'; | ||||
|         color: #777; | ||||
|         font-weight: bold; | ||||
|         float: right; | ||||
|         margin-left: 2px; | ||||
|       } | ||||
|  | ||||
|     .collapsible:after { | ||||
|       content: '\002B'; | ||||
|       color: #777; | ||||
|       font-weight: bold; | ||||
|       float: right; | ||||
|       margin-left: 2px; | ||||
|     } | ||||
|       .active:after { | ||||
|         content: '\2212'; | ||||
|       } | ||||
|  | ||||
|     .active:after { | ||||
|       content: "\2212"; | ||||
|     } | ||||
|       .content { | ||||
|         padding: 0 5px; | ||||
|         max-height: 0; | ||||
|         overflow: hidden; | ||||
|         transition: max-height 0.2s ease-out; | ||||
|         background-color: #f1f1f1; | ||||
|       } | ||||
|  | ||||
|     .content { | ||||
|       padding: 0 5px; | ||||
|       max-height: 0; | ||||
|       overflow: hidden; | ||||
|       transition: max-height 0.2s ease-out; | ||||
|       background-color: #f1f1f1; | ||||
|     } | ||||
|       .content .pre-scrollable { | ||||
|         max-height: 200px; | ||||
|         overflow-y: scroll; | ||||
|       } | ||||
|     </style> | ||||
|   </head> | ||||
|  | ||||
|     .content .pre-scrollable { | ||||
|       max-height: 200px; | ||||
|       overflow-y: scroll; | ||||
|     } | ||||
|   </style> | ||||
| </head> | ||||
|  | ||||
| <body> | ||||
|   <table> | ||||
|     <tr> | ||||
|       <th></th> <!-- Placeholder for the top left corner --> | ||||
|       <th>State rough</th> | ||||
|       <th>Flowchart rough</th> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <th class="vertical-header"> | ||||
|         <button class="collapsible">Stadium shape</button> | ||||
|         <div class="content"> | ||||
|           <div class="pre-scrollable"> | ||||
|             <pre> | ||||
|   <body> | ||||
|     <table> | ||||
|       <tr> | ||||
|         <th></th> | ||||
|         <!-- Placeholder for the top left corner --> | ||||
|         <th>State rough</th> | ||||
|         <th>Flowchart rough</th> | ||||
|       </tr> | ||||
|       <tr> | ||||
|         <th class="vertical-header"> | ||||
|           <button class="collapsible">Stadium shape</button> | ||||
|           <div class="content"> | ||||
|             <div class="pre-scrollable"> | ||||
|               <pre> | ||||
|       flowchart LR | ||||
|     id1([This is the text in the box]) | ||||
|  | ||||
|   </pre> | ||||
|   </pre | ||||
|               > | ||||
|             </div> | ||||
|           </div> | ||||
|       </th> | ||||
|       <td> | ||||
|         <pre id="diagram1" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
|         </th> | ||||
|         <td> | ||||
|           <pre id="diagram1" class="mermaid"> | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
| stateDiagram-v2 | ||||
|     stateA | ||||
|  | ||||
|       </pre> | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
|       </pre | ||||
|           > | ||||
|         </td> | ||||
|         <td> | ||||
|           <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
| flowchart LR | ||||
|     id1[[This is the text in the box]] | ||||
|  | ||||
|  | ||||
|       </pre> | ||||
|       </td> | ||||
|       </pre | ||||
|           > | ||||
|         </td> | ||||
|       </tr> | ||||
|     </table> | ||||
|  | ||||
|     </tr> | ||||
|     <script type="module"> | ||||
|       import mermaid from './mermaid.esm.mjs'; | ||||
|       import layouts from './mermaid-layout-elk.esm.mjs'; | ||||
|       mermaid.registerLayoutLoaders(layouts); | ||||
|       mermaid.parseError = function (err, hash) {}; | ||||
|  | ||||
|  | ||||
|   </table> | ||||
|  | ||||
|  | ||||
|   <script type="module"> | ||||
|     import mermaid from './mermaid.esm.mjs'; | ||||
|     import { layouts } from './mermaid-layout-elk.esm.mjs'; | ||||
|     mermaid.registerLayoutLoaders(layouts); | ||||
|     mermaid.parseError = function (err, hash) { | ||||
|  | ||||
|     }; | ||||
|  | ||||
|     mermaid.initialize({ | ||||
|       handdrawn: false, | ||||
|       mergeEdges: true, | ||||
|       layout: 'dagre', | ||||
|       flowchart: { titleTopMargin: 10 }, | ||||
|       // fontFamily: 'Caveat', | ||||
|       fontFamily: 'Kalam', | ||||
|       sequence: { | ||||
|         actorFontFamily: 'courier', | ||||
|         noteFontFamily: 'courier', | ||||
|         messageFontFamily: 'courier', | ||||
|       }, | ||||
|       fontSize: 16, | ||||
|       logLevel: 0, | ||||
|     }); | ||||
|     function callback() { | ||||
|       alert('It worked'); | ||||
|     } | ||||
|     mermaid.parseError = function (err, hash) { | ||||
|       console.error('In parse error:'); | ||||
|       console.error(err); | ||||
|     }; | ||||
|  | ||||
|  | ||||
|     let coll = document.getElementsByClassName("collapsible"); | ||||
|     for (const element of coll) { | ||||
|   element.addEventListener("click", function () { | ||||
|         this.classList.toggle("active"); | ||||
|         let content = this.nextElementSibling; | ||||
|         if (content.style.maxHeight) { | ||||
|           content.style.maxHeight = null; | ||||
|         } else { | ||||
|           content.style.maxHeight = content.scrollHeight + "px"; | ||||
|         } | ||||
|       mermaid.initialize({ | ||||
|         handDrawn: false, | ||||
|         mergeEdges: true, | ||||
|         layout: 'dagre', | ||||
|         flowchart: { titleTopMargin: 10 }, | ||||
|         // fontFamily: 'Caveat', | ||||
|         fontFamily: 'Kalam', | ||||
|         sequence: { | ||||
|           actorFontFamily: 'courier', | ||||
|           noteFontFamily: 'courier', | ||||
|           messageFontFamily: 'courier', | ||||
|         }, | ||||
|         fontSize: 16, | ||||
|         logLevel: 0, | ||||
|       }); | ||||
|     } | ||||
|       function callback() { | ||||
|         alert('It worked'); | ||||
|       } | ||||
|       mermaid.parseError = function (err, hash) { | ||||
|         console.error('In parse error:'); | ||||
|         console.error(err); | ||||
|       }; | ||||
|  | ||||
|   </script> | ||||
| </body> | ||||
|  | ||||
| </html> | ||||
|       let coll = document.getElementsByClassName('collapsible'); | ||||
|       for (const element of coll) { | ||||
|         element.addEventListener('click', function () { | ||||
|           this.classList.toggle('active'); | ||||
|           let content = this.nextElementSibling; | ||||
|           if (content.style.maxHeight) { | ||||
|             content.style.maxHeight = null; | ||||
|           } else { | ||||
|             content.style.maxHeight = content.scrollHeight + 'px'; | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     </script> | ||||
|   </body> | ||||
| </html> | ||||
|   | ||||
| @@ -36,12 +36,15 @@ | ||||
|         font-family: 'Arial'; | ||||
|         /* font-size: 18px !important; */ | ||||
|       } | ||||
|  | ||||
|       h1 { | ||||
|         color: grey; | ||||
|       } | ||||
|  | ||||
|       .mermaid2 { | ||||
|         display: none; | ||||
|       } | ||||
|  | ||||
|       .mermaid svg { | ||||
|         /* font-size: 18px !important; */ | ||||
|  | ||||
| @@ -54,6 +57,7 @@ | ||||
|           10px 10px; | ||||
|         background-repeat: repeat; */ | ||||
|       } | ||||
|  | ||||
|       .malware { | ||||
|         position: fixed; | ||||
|         bottom: 0; | ||||
| @@ -69,204 +73,391 @@ | ||||
|         font-family: monospace; | ||||
|         font-size: 72px; | ||||
|       } | ||||
|       pre { | ||||
|         width: 100%; | ||||
|       } | ||||
|       /* tspan { | ||||
|               font-size: 6px !important; | ||||
|             } */ | ||||
|     </style> | ||||
|   </head> | ||||
|   <body> | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
| %%{ | ||||
|   init: { | ||||
|   "theme":"base", | ||||
|   "fontFamily": "Kalam", | ||||
|   "themeVariables": { | ||||
|     "background": "#FFFFFF", | ||||
|     "primaryColor": "#7bdfa7", | ||||
|     "primaryTextColor": "#3c3c3b", | ||||
|     "secondaryColor": "#642470", | ||||
|     "secondaryTextColor": "#3c3c3b", | ||||
|     "tertiaryColor": "#1c736D", | ||||
|     "tertiaryTextColor": "#3c3c3b", | ||||
|     "noteBkgColor": "#9fd8ef", | ||||
|     "loopTextColor": "#636362", | ||||
|     "labelBoxBkgColor": "#642470", | ||||
|     "labelBoxBorderColor": "#642470", | ||||
|     "labelTextColor": "#d4d4d4", | ||||
|     "signalTextColor": "#636362", | ||||
|     "signalColor": "#642470" | ||||
|   } | ||||
|   } | ||||
| }%% | ||||
| sequenceDiagram | ||||
|     Alice->>+John: Hello John, how are you? | ||||
|     Alice->>+John: John, can you hear me? | ||||
|     John-->>-Alice: Hi Alice, I can hear you! | ||||
|     John-->>-Alice: I feel great! | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
| %%{ | ||||
|   init: { | ||||
|     "theme":"base", | ||||
|   "fontFamily": "Forth Bold", | ||||
|   "themeVariables": { | ||||
|     "background": "#FFFFFF", | ||||
|     "primaryColor": "#7bdfa7", | ||||
|     "primaryTextColor": "#3c3c3b", | ||||
|     "secondaryColor": "#642470", | ||||
|     "secondaryTextColor": "#3c3c3b", | ||||
|     "tertiaryColor": "#1c736D", | ||||
|     "tertiaryTextColor": "#3c3c3b", | ||||
|     "noteBkgColor": "#9fd8ef", | ||||
|     "loopTextColor": "#636362", | ||||
|     "labelBoxBkgColor": "#642470", | ||||
|     "labelBoxBorderColor": "#642470", | ||||
|     "labelTextColor": "#d4d4d4", | ||||
|     "signalTextColor": "#636362", | ||||
|     "signalColor": "#642470" | ||||
|   } | ||||
|   } | ||||
| }%% | ||||
| sequenceDiagram | ||||
|     Alice->>+John: Hello John, how are you? | ||||
|     Alice->>+John: John, can you hear me? | ||||
|     John-->>-Alice: Hi Alice, I can hear you! | ||||
|     John-->>-Alice: I feel great! | ||||
|       </pre | ||||
|     > | ||||
|  | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "elk", "mergeEdges": true} }%% | ||||
| stateDiagram | ||||
|       A --> B | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid"> | ||||
|       %%{init: {"layout": "elk", "mergeEdges": true} }%% | ||||
| flowchart | ||||
|       A --> B(This is B) | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "elk", "mergeEdges": false, "elk.nodePlacement.strategy": "NETWORK_SIMPLEX"} }%% | ||||
| stateDiagram | ||||
|   State T0 { | ||||
|     direction LR | ||||
|     A --> B | ||||
|   } | ||||
|   State T1 { | ||||
|     [*] --> NumLockOff | ||||
|     NumLockOff --> NumLockOn : EvNumLockPressed | ||||
|     NumLockOn --> NumLockOff : EvNumLockPressed | ||||
|   } | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "dagre", "mergeEdges": true} }%% | ||||
| stateDiagram | ||||
|   direction TB | ||||
|   State T1 { | ||||
|     T11 | ||||
|   } | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "dagre", "mergeEdges": true} }%% | ||||
| stateDiagram | ||||
| State T1 { | ||||
|     T21 | ||||
|     -- | ||||
|     T22 | ||||
|     } | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "elk", "mergeEdges": true} }%% | ||||
| stateDiagram | ||||
|   direction TB | ||||
|   State T1 { | ||||
|     T11 | ||||
|   } | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "elk", "mergeEdges": true} }%% | ||||
| stateDiagram | ||||
| State T1 { | ||||
|     T21 | ||||
|     -- | ||||
|     T22 | ||||
|     } | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "elk", "mergeEdges": true} }%% | ||||
| stateDiagram | ||||
|   [*] --> T1 | ||||
|   T1 --> T2 | ||||
|   T1 --> T3 | ||||
|   T1 --> T4 | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|       %%{init: {"layout": "elk"} }%% | ||||
| stateDiagram | ||||
|   [*] --> T1 | ||||
|   T1 --> T2 | ||||
|   T2 --> T3 | ||||
|   T3 --> T1 | ||||
|   T1 --> T3 | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
| stateDiagram | ||||
|   State1: The state with a note | ||||
|   note right of State1 | ||||
|       Important information! You can write | ||||
|       notes. | ||||
|   end note | ||||
|       </pre | ||||
|     > | ||||
|     <pre id="diagram" class="mermaid2"> | ||||
|   <body> | ||||
|     <div class="flex"> | ||||
|       <pre id="diagram" class="mermaid2"> | ||||
| --- | ||||
|   title: hello2 | ||||
|   config: | ||||
|     look: handDrawn | ||||
|     layout: elk | ||||
|     elk: | ||||
|         <!-- nodePlacementStrategy: INTERACTIVE --> | ||||
|         <!-- mergeEdges: true --> | ||||
| --- | ||||
| stateDiagram-v2 | ||||
|     direction LR | ||||
|     [*] --> Active | ||||
|     accTitle: An idealized Open Source supply-chain graph | ||||
|  | ||||
|     state Active { | ||||
|       direction BT | ||||
|         [*] --> Inner | ||||
|         Inner --> NumLockOn : EvNumLockPressed | ||||
|     %% | ||||
|     state "🟦 Importer" as author_importer | ||||
|     state "🟥 Supplier, Owner" as author_owner | ||||
|     state "🟨🟥 Maintainer, Author\n🟨 Custodian" as author | ||||
|     state "🟩 Distributor" as repository_distributor | ||||
|     state "🟦 Importer" as language_importer | ||||
|     state "🟦🟨 Packager" as language_packager | ||||
|     state "🟦🟨 OSS Steward" as language_steward | ||||
|     state "🟨 Curator" as language_curator | ||||
|     state "🟩 Distributor" as language_distributor | ||||
|     state "🟦 Contributor" as contributor | ||||
|     state "🟦 Importer" as package_importer | ||||
|     state "🟨 Patcher" as package_patcher | ||||
|     state "🟨🟦 Builder\n🟨🟦 Packager\n🟨🟦 Containerizer" as package_packager | ||||
|     state "🟨 Curator" as package_curator | ||||
|     state "🟩 Distributor" as package_distributor | ||||
|     state "🟦 Importer" as integrator_importer | ||||
|     state "🟥 Supplier, Manufacturer, Owner" as integrator_owner | ||||
|     state "🟦🟨🟥 Integrator, Developer" as integrator_developer | ||||
|     state "🟩🟨 SBOM Redactor\n🟩 Publisher" as integrator_publisher | ||||
|     state "🟦🟨 Builder" as integrator_builder | ||||
|     state "🟨 Deployer" as deployer | ||||
|     state "🟦 Vuln. Checker" as integrator_checker | ||||
|     state "🟩🟨 SBOM Redactor" as redactor | ||||
|     state "🟦 Consumer\n🟦  User" as consumer | ||||
|     state "🟦 Auditor" as auditor_internal | ||||
|     state "🟦 Auditor" as auditor_external | ||||
|  | ||||
|     %% | ||||
|     classDef createsSBOM stroke:red,stroke-width:3px; | ||||
|     classDef updatesSBOM stroke:yellow,stroke-width:3px; | ||||
|     classDef assemblesSBOM stroke:yellow,stroke-width:3px; | ||||
|     classDef distributesSBOM stroke:green,stroke-width:3px; | ||||
|     classDef verifiesSBOM stroke:#07f,stroke-width:3px; | ||||
|  | ||||
|     %% | ||||
|     class author_importer verifiesSBOM | ||||
|     class author_owner createsSBOM | ||||
|     class manufacturer_owner createsSBOM | ||||
|     class author assemblesSBOM | ||||
|     class package_importer verifiesSBOM | ||||
|     class package_patcher updatesSBOM | ||||
|     class package_packager assemblesSBOM | ||||
|     class package_curator distributesSBOM | ||||
|     class package_distributor distributesSBOM | ||||
|     class language_importer verifiesSBOM | ||||
|     class language_packager assemblesSBOM | ||||
|     class language_steward updatesSBOM | ||||
|     class language_curator distributesSBOM | ||||
|     class language_distributor distributesSBOM | ||||
|     class repository_distributor distributesSBOM | ||||
|     class integrator_importer verifiesSBOM | ||||
|     class integrator_owner createsSBOM | ||||
|     class integrator_developer assemblesSBOM | ||||
|     class integrator_publisher distributesSBOM | ||||
|     class integrator_builder assemblesSBOM | ||||
|     class integrator_checker verifiesSBOM | ||||
|     class deployer assemblesSBOM | ||||
|     class redactor distributesSBOM | ||||
|     class auditor_internal verifiesSBOM | ||||
|     class auditor_external verifiesSBOM | ||||
|  | ||||
|     state "Maintainer Environment" as environment_maintainer { | ||||
|         [*] --> author_importer | ||||
|         [*] --> author | ||||
|         author_importer --> author | ||||
|         author_owner --> author | ||||
|         author       --> language_packager | ||||
|     } | ||||
|     %% Outer --> Inner | ||||
|       </pre | ||||
|     > | ||||
|  | ||||
|     [*] --> environment_maintainer | ||||
|  | ||||
|     state "Language Ecosystem" as ecosystem_lang { | ||||
|         [*] --> language_importer | ||||
|         [*] --> language_steward | ||||
|         [*] --> language_curator | ||||
|         [*] --> language_distributor | ||||
|         language_importer --> language_distributor | ||||
|         language_importer --> language_curator | ||||
|         language_steward --> language_curator | ||||
|         language_curator --> language_distributor | ||||
|     } | ||||
|  | ||||
|     language_packager --> ecosystem_lang | ||||
|     ecosystem_lang    --> ecosystem_lang | ||||
|  | ||||
|     state "Public Collaboration Ecosystem" as ecosystem_repo { | ||||
|         [*] --> repository_distributor | ||||
|     } | ||||
|  | ||||
|     author         --> ecosystem_repo | ||||
|     ecosystem_repo --> author | ||||
|  | ||||
|     repository_distributor --> contributor | ||||
|     contributor            --> repository_distributor | ||||
|  | ||||
|     state "Package Ecosystem" as ecosystem_package { | ||||
|         [*] --> package_importer | ||||
|         [*] --> package_packager | ||||
|         [*] --> package_patcher | ||||
|         package_importer --> package_patcher | ||||
|         package_importer --> package_packager | ||||
|         package_patcher  --> package_packager | ||||
|         package_packager --> package_curator | ||||
|         package_packager --> package_distributor | ||||
|         package_curator  --> package_distributor | ||||
|     } | ||||
|  | ||||
|     repository_distributor --> ecosystem_package | ||||
|     language_distributor   --> ecosystem_package | ||||
|     ecosystem_package      --> ecosystem_package | ||||
|  | ||||
|     state "Integrator Environment" as environment_integrator { | ||||
|         [*] --> integrator_developer | ||||
|         [*] --> integrator_importer | ||||
|         integrator_importer  --> integrator_developer | ||||
|         integrator_owner     --> integrator_developer | ||||
|         integrator_builder   --> integrator_publisher | ||||
|         integrator_developer --> integrator_checker | ||||
|         integrator_checker   --> integrator_developer | ||||
|         auditor_internal     --> integrator_developer | ||||
|         integrator_developer --> integrator_builder | ||||
|         integrator_developer --> auditor_internal | ||||
|     } | ||||
|  | ||||
|     repository_distributor --> environment_integrator | ||||
|     language_distributor   --> environment_integrator | ||||
|     package_distributor    --> environment_integrator | ||||
|  | ||||
|     state "Production Environment" as environment_prod { | ||||
|         [*] --> deployer | ||||
|         deployer --> redactor | ||||
|     } | ||||
|  | ||||
|     integrator_publisher --> [*] | ||||
|     integrator_developer --> environment_prod | ||||
|     integrator_builder   --> environment_prod | ||||
|     integrator_publisher --> environment_prod | ||||
|  | ||||
|     deployer --> auditor_external | ||||
|     deployer --> consumer | ||||
|     redactor --> consumer | ||||
|  | ||||
|  | ||||
|  | ||||
| </pre> | ||||
|  | ||||
|       <pre id="diagram" class="mermaid2"> | ||||
| --- | ||||
| config: | ||||
|   look: neo | ||||
| --- | ||||
| flowchart RL | ||||
|     subgraph "   " | ||||
|         A5@{ shape: manual-file, label: "a label"} | ||||
|         B5@{ shape: manual-input, label: "a label" } | ||||
|         C5@{ shape: mul-doc, label: "a label" } | ||||
|         D5@{ shape: mul-proc, label: "a label" } | ||||
|         E5@{ shape: paper-tape, label: "a label" } | ||||
|         B3@{ shape: das, label: "a label" } | ||||
|         C3@{ shape: disk, label: "a label" } | ||||
|         D4@{ shape: lin-doc, label: "a label" } | ||||
|         E4@{ shape: loop-limit, label: "a label" } | ||||
|     end | ||||
|     subgraph "   " | ||||
|         B6@{ shape: summary, label: "a label" } | ||||
|         C6@{ shape: tag-we-rect, label: "a label" } | ||||
|         D6@{ shape: tag-rect, label: "a label" } | ||||
|         A2@{ shape: fork} | ||||
|         B2@{ shape: hourglass } | ||||
|         C2@{ shape: comment, label: "I am a comment" } | ||||
|         D2@{ shape: bolt } | ||||
|         D3@{ shape: disp, label: "a label" } | ||||
|         C4@{ shape: junction, label: "a label" } | ||||
|         A4@{ shape: extract, label: "a label"} | ||||
|         B52[a fr]@{ shape: fr } | ||||
|     end | ||||
|     subgraph " " | ||||
|         A1@{ shape: text, label: This is a textblock} | ||||
|         B1@{ shape: card, label: "a label" } | ||||
|         C1@{ shape: lined-proc, label: "a label" } | ||||
|         D1@{ shape: start, label: "a label" } | ||||
|         E1@{ shape: stop, label: "a label" } | ||||
|         E2@{ shape: doc, label: "a label" } | ||||
|         A6@{ shape: stored-data, label: "a label"} | ||||
|         A3@{ shape: delay, label: "a label" } | ||||
|         E3@{ shape: div-proc, label: "a label" } | ||||
|         B4[a label]@{ shape: win-pane } | ||||
|     end | ||||
|       </pre> | ||||
|       <pre id="diagram" class="mermaid2"> | ||||
| --- | ||||
|   title: hello2 | ||||
|   config: | ||||
|     look: handDrawn | ||||
|     elk: | ||||
|       <!-- nodePlacementStrategy: SIMPLE --> | ||||
| --- | ||||
| %%{init: {"flowchart": {"defaultRenderer": "elk"}} }%% | ||||
| flowchart TD | ||||
|  | ||||
|     A([Start]) -->|go to booking page| B("select | ||||
|     ISBS booking no") | ||||
|     A --> QQ{cancel booking} | ||||
|     A --> RR{no show} | ||||
|     A --> SS{change booking} | ||||
|     B -->C(wmpay_request_payment.request_type= 'partial', | ||||
|  wmpay_request_payment.status= 'paid', | ||||
|  pos_booking.booking_status= ‘partial’ and 'full_deposit') | ||||
|  style C text-align:left | ||||
|     C -->D{manage booking} | ||||
|  | ||||
|     D -->|cancel|E[ระบบแสดงช่องให้กรอกเหตุผล] | ||||
|     E -->F{กดปุ่ม 'cancel' หรือไม่} | ||||
|     F -->|Yes|G[ระบบบันทึกค่าใหม่ | ||||
|     และไม่สามารถแก้ไขข้อมูลได้] | ||||
|     F -->|No|H[กดปุ่ม 'close'] | ||||
|     H -->|ระบบไม่เปลี่ยนแปลงข้อมูล|Z | ||||
|     G -->|ระบบส่งข้อมูล|I[(POS_database)] | ||||
|     I -->|pos_booking.booking_status='cancel'|Z([End]) | ||||
|  | ||||
|  | ||||
|     D -->|no show|J[ระบบแสดงช่องให้กรอกเหตุผล] | ||||
|     J -->K{กดปุ่ม 'noshow' หรือไม่} | ||||
|     K -->|Yes|L[ระบบสร้างใบเสร็จอัตโนมัติ | ||||
|     Product_id: 439, | ||||
|     ItemName: no show] | ||||
|      style L text-align:left | ||||
|  | ||||
|      K -->|No|O[กดปุ่ม 'close'] | ||||
|      O -->|ระบบไม่เปลี่ยนแปลงข้อมูล|Z | ||||
|     L -->M[ระบบบันทึกค่าใหม่] | ||||
|     M -->|ระบบส่งข้อมูล|N[(POS_database)] | ||||
|     N -->|pos_booking.booking_status=‘noshow’|Z | ||||
|  | ||||
|  | ||||
|  | ||||
| </pre> | ||||
|       <pre id="diagram" class="mermaid2"> | ||||
| --- | ||||
|   title: hello2 | ||||
|   config: | ||||
|     look: handDrawn | ||||
|     layout: dagre | ||||
|     elk: | ||||
|         nodePlacementStrategy: BRANDES_KOEPF | ||||
| --- | ||||
| flowchart | ||||
|   A --> A | ||||
|   subgraph A | ||||
|     B --> B | ||||
|     subgraph B | ||||
|       C | ||||
|     end | ||||
|   end | ||||
|  | ||||
|  | ||||
| </pre | ||||
|       > | ||||
|       <pre id="diagram" class="mermaid2"> | ||||
| --- | ||||
| config: | ||||
|   look: handdrawn | ||||
|   flowchart: | ||||
|     htmlLabels: true | ||||
| --- | ||||
| flowchart | ||||
|       A[I am a long text, where do I go??? handdrawn - true] | ||||
| </pre | ||||
|       > | ||||
|     </div> | ||||
|     <div class="flex"> | ||||
|       <pre id="diagram" class="mermaid2"> | ||||
| --- | ||||
| config: | ||||
|   flowchart: | ||||
|     htmlLabels: false | ||||
| --- | ||||
| flowchart | ||||
|       A[I am a long text, where do I go??? classic - false] | ||||
| </pre | ||||
|       > | ||||
|       <pre id="diagram" class="mermaid2"> | ||||
| --- | ||||
| config: | ||||
|   flowchart: | ||||
|     htmlLabels: true | ||||
| --- | ||||
| flowchart | ||||
|       A[I am a long text, where do I go??? classic - true] | ||||
| </pre | ||||
|       > | ||||
|     </div> | ||||
|     <pre id="diagram2" class="mermaid2"> | ||||
| flowchart LR | ||||
|     id1(Start)-->id2(Stop) | ||||
|     style id1 fill:#f9f,stroke:#333,stroke-width:4px | ||||
|     style id2 fill:#bbf,stroke:#f66,stroke-width:2px,color:#fff,stroke-dasharray: 5 5 | ||||
|  | ||||
|  | ||||
|     </pre> | ||||
|  | ||||
|     <pre id="diagram3" class="mermaid2"> | ||||
|       flowchart LR | ||||
|     A:::foo & B:::bar --> C:::foobar | ||||
|     classDef foo stroke:#f00 | ||||
|     classDef bar stroke:#0f0 | ||||
|     classDef ash color:red | ||||
|     class C ash | ||||
|     style C stroke:#00f, fill:black | ||||
|  | ||||
|     </pre> | ||||
|  | ||||
|     <pre id="diagram4" class="mermaid2"> | ||||
|       stateDiagram | ||||
|     A:::foo | ||||
|     B:::bar --> C:::foobar | ||||
|     classDef foo stroke:#f00 | ||||
|     classDef bar stroke:#0f0 | ||||
|     style C stroke:#00f, fill:black, color:white | ||||
|  | ||||
|     </pre> | ||||
|  | ||||
|     <pre id="diagram4" class="mermaid"> | ||||
| flowchart TB | ||||
|   A@{ | ||||
|     label: "aksljhf kasjdh" | ||||
|   } | ||||
|     </pre> | ||||
|     <script type="module"> | ||||
|       import mermaid from './mermaid.esm.mjs'; | ||||
|       import { layouts } from './mermaid-layout-elk.esm.mjs'; | ||||
|       import layouts from './mermaid-layout-elk.esm.mjs'; | ||||
|       mermaid.registerLayoutLoaders(layouts); | ||||
|       mermaid.parseError = function (err, hash) { | ||||
|         console.error('Mermaid error: ', err); | ||||
|       }; | ||||
|       window.callback = function () { | ||||
|         alert('A callback was triggered'); | ||||
|       }; | ||||
|       mermaid.initialize({ | ||||
|         theme: 'base', | ||||
|         handdrawnSeed: 12, | ||||
|         look: 'handdrawn', | ||||
|         'elk.nodePlacement.strategy': 'NETWORK_SIMPLEX', | ||||
|         // theme: 'base', | ||||
|         // handDrawnSeed: 12, | ||||
|         // look: 'handDrawn', | ||||
|         // 'elk.nodePlacement.strategy': 'NETWORK_SIMPLEX', | ||||
|         // layout: 'dagre', | ||||
|         layout: 'elk', | ||||
|         // layout: 'elk', | ||||
|         // layout: 'fixed', | ||||
|         // htmlLabels: false, | ||||
|         flowchart: { titleTopMargin: 10 }, | ||||
|         // fontFamily: 'Caveat', | ||||
|         // fontFamily: 'Kalam', | ||||
|         fontFamily: 'courier', | ||||
|         // fontFamily: 'courier', | ||||
|         sequence: { | ||||
|           actorFontFamily: 'courier', | ||||
|           noteFontFamily: 'courier', | ||||
|           messageFontFamily: 'courier', | ||||
|         }, | ||||
|         fontSize: 12, | ||||
|         logLevel: 0, | ||||
|         logLevel: 3, | ||||
|         securityLevel: 'loose', | ||||
|       }); | ||||
|       function callback() { | ||||
|         alert('It worked'); | ||||
| @@ -275,10 +466,6 @@ stateDiagram-v2 | ||||
|         console.error('In parse error:'); | ||||
|         console.error(err); | ||||
|       }; | ||||
|       // mermaid.test1('first_slow', 1200).then((r) => console.info(r)); | ||||
|       // mermaid.test1('second_fast', 200).then((r) => console.info(r)); | ||||
|       // mermaid.test1('third_fast', 200).then((r) => console.info(r)); | ||||
|       // mermaid.test1('forth_slow', 1200).then((r) => console.info(r)); | ||||
|     </script> | ||||
|   </body> | ||||
| </html> | ||||
|   | ||||
							
								
								
									
										174
									
								
								cypress/platform/saurabh.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								cypress/platform/saurabh.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,174 @@ | ||||
| <html> | ||||
|   <head> | ||||
|     <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" /> | ||||
|     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> | ||||
|     <link | ||||
|       rel="stylesheet" | ||||
|       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://cdn.jsdelivr.net/npm/@mdi/font@6.9.96/css/materialdesignicons.min.css" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link rel="preconnect" href="https://fonts.googleapis.com" /> | ||||
|     <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&family=Kalam:wght@300;400;700&family=Rubik+Mono+One&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|     <link | ||||
|       href="https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&family=Rubik+Mono+One&display=swap" | ||||
|       rel="stylesheet" | ||||
|     /> | ||||
|  | ||||
|     <style> | ||||
|       body { | ||||
|         /* background: rgb(221, 208, 208); */ | ||||
|         /* background: #333; */ | ||||
|         font-family: 'Arial'; | ||||
|         /* font-size: 18px !important; */ | ||||
|       } | ||||
|  | ||||
|       h1 { | ||||
|         color: grey; | ||||
|       } | ||||
|  | ||||
|       .mermaid2 { | ||||
|         display: none; | ||||
|       } | ||||
|  | ||||
|       .mermaid svg { | ||||
|         /* font-size: 18px !important; */ | ||||
|  | ||||
|         /* background-color: #efefef; | ||||
|         background-image: radial-gradient(#fff 51%, transparent 91%), | ||||
|           radial-gradient(#fff 51%, transparent 91%); | ||||
|         background-size: 20px 20px; | ||||
|         background-position: | ||||
|           0 0, | ||||
|           10px 10px; | ||||
|         background-repeat: repeat; */ | ||||
|       } | ||||
|     </style> | ||||
|   </head> | ||||
|  | ||||
|   <body style="display: flex; gap: 2rem; flex-direction: row"> | ||||
|     <pre id="diagram4" class="mermaid"> | ||||
|       flowchart LR | ||||
|       A@{ icon: "fa:window-minimize", form: circle } | ||||
|       E@{ icon: "fa:window-minimize", form: circle } | ||||
|       B@{ icon: "fa:bell", form: circle } | ||||
|       B2@{ icon: "fa:bell", form: circle } | ||||
|       C@{ icon: "fa:address-book",  form: square  } | ||||
|       D@{ icon: "fa:star-half",  form: square  } | ||||
|       A --> E | ||||
|       B --> B2 | ||||
|  | ||||
|  | ||||
|     </pre> | ||||
|     <pre id="diagram4" class="mermaid2"> | ||||
|       flowchart TB | ||||
|        A --test2--> B2@{ icon: "fa:bell", form: "rounded", label: "B2 aiduaid uyawduad uaduabd uyduadb", pos: "b" } | ||||
|        B2 --test--> C | ||||
|        D --> B2 --> E | ||||
|        style B2 fill:#f9f,stroke:#333,stroke-width:4px | ||||
|   </pre | ||||
|     > | ||||
|     <pre id="diagram43" class="mermaid2"> | ||||
|       flowchart BT | ||||
|        A --test2--> B2@{ icon: "fa:bell", form: "square", label: "B2", pos: "t", h: 40, w: 30 } | ||||
|        B2 --test--> C | ||||
|        D --> B2 --> E | ||||
|   </pre | ||||
|     > | ||||
|     <pre id="diagram4" class="mermaid2"> | ||||
|       flowchart BT | ||||
|        A --test2--> B2@{ icon: "fa:bell", label: "B2 awiugdawu uydgayuiwd wuydguy", pos: "b", h: 40, w: 30 } | ||||
|        B2 --test--> C | ||||
|   </pre | ||||
|     > | ||||
|     <pre id="diagram43" class="mermaid2"> | ||||
|       flowchart BT | ||||
|        A --test2--> B2@{ icon: "fa:bell", label: "B2 dawuygd ayuwgd uy", pos: "t", h: 40, w: 30 } | ||||
|        B2 --test--> C | ||||
|   </pre | ||||
|     > | ||||
|     <pre id="diagram6" class="mermaid2"> | ||||
|       flowchart TB | ||||
|        A --> B2@{ icon: "fa:bell", form: "circle", label: "test augfuyfavf ydvaubfuac", pos: "t", w: 200, h: 100 } --> C | ||||
|   </pre | ||||
|     > | ||||
|     <pre id="diagram6" class="mermaid2"> | ||||
|       flowchart TB | ||||
|        A --> B2@{ icon: "fa:bell", form: "circle", label: "test augfuyfavf ydvaubfuac", pos: "b", w: 200, h: 100 } --> C | ||||
|        D --> B2 --> E | ||||
|   </pre | ||||
|     > | ||||
|     <script type="module"> | ||||
|       import mermaid from './mermaid.esm.mjs'; | ||||
|       import layouts from './mermaid-layout-elk.esm.mjs'; | ||||
|       mermaid.registerLayoutLoaders(layouts); | ||||
|       mermaid.registerIconPacks([ | ||||
|         { | ||||
|           name: 'logos', | ||||
|           loader: () => | ||||
|             fetch('https://unpkg.com/@iconify-json/logos/icons.json').then((res) => res.json()), | ||||
|         }, | ||||
|         { | ||||
|           name: 'fa', | ||||
|           loader: () => | ||||
|             fetch('https://unpkg.com/@iconify-json/fa6-solid/icons.json').then((res) => res.json()), | ||||
|         }, | ||||
|       ]); | ||||
|       mermaid.parseError = function (err, hash) { | ||||
|         console.error('Mermaid error: ', err); | ||||
|       }; | ||||
|       window.callback = function () { | ||||
|         alert('A callback was triggered'); | ||||
|       }; | ||||
|       mermaid.initialize({ | ||||
|         // theme: 'base', | ||||
|         // handdrawnSeed: 12, | ||||
|         look: 'classic', | ||||
|         // 'elk.nodePlacement.strategy': 'NETWORK_SIMPLEX', | ||||
|         // 'elk.nodePlacement.strategy': 'SIMPLE', | ||||
|         // 'elk.nodePlacement.strategy': 'LAYERED', | ||||
|         // 'elk.mergeEdges': true, | ||||
|         // layout: 'dagre', | ||||
|         // layout: 'elk', | ||||
|         // layout: 'fixed', | ||||
|         // htmlLabels: false, | ||||
|         flowchart: { titleTopMargin: 10, padding: 0, htmlLabels: true }, | ||||
|         // fontFamily: 'Caveat', | ||||
|         // fontFamily: 'Kalam', | ||||
|         fontFamily: 'courier', | ||||
|         sequence: { | ||||
|           actorFontFamily: 'courier', | ||||
|           noteFontFamily: 'courier', | ||||
|           messageFontFamily: 'courier', | ||||
|         }, | ||||
|         themeVariables: { | ||||
|           fontSize: 50, | ||||
|           fontFamily: 'courier', | ||||
|         }, | ||||
|         logLevel: 0, | ||||
|         securityLevel: 'loose', | ||||
|       }); | ||||
|       function callback() { | ||||
|         alert('It worked'); | ||||
|       } | ||||
|       mermaid.parseError = function (err, hash) { | ||||
|         console.error('In parse error:'); | ||||
|         console.error(err); | ||||
|       }; | ||||
|     </script> | ||||
|   </body> | ||||
| </html> | ||||
| @@ -105,6 +105,7 @@ | ||||
|       stateId | ||||
|   </pre> | ||||
|           </div> | ||||
|         </div> | ||||
|       </th> | ||||
|       <td> | ||||
|         <pre id="diagram1" class="mermaid"> | ||||
| @@ -114,7 +115,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
| stateDiagram-v2 | ||||
|     stateId | ||||
|  | ||||
| @@ -122,7 +123,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     stateId | ||||
|  | ||||
| @@ -130,7 +131,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     stateId | ||||
|  | ||||
| @@ -161,21 +162,21 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
| stateDiagram-v2 | ||||
|     state "This is a state description" as s3 | ||||
|       </pre> | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     state "This is a state description" as s4 | ||||
|       </pre> | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     state "This is a state description" as s5 | ||||
|       </pre> | ||||
| @@ -205,7 +206,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
| stateDiagram-v2 | ||||
|     s22 : This is a state description | ||||
|  | ||||
| @@ -213,7 +214,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     s23 : This is a state description | ||||
|  | ||||
| @@ -221,7 +222,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     s24 : This is a state description | ||||
|  | ||||
| @@ -257,7 +258,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|  | ||||
|    stateDiagram-v2 | ||||
|     s41 --> s42 | ||||
| @@ -267,7 +268,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     s51 --> s52 | ||||
|  | ||||
| @@ -276,7 +277,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     s61 --> s62 | ||||
|  | ||||
| @@ -315,7 +316,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|  | ||||
|    stateDiagram-v2 | ||||
|     a3 --> a4: A transition | ||||
| @@ -325,7 +326,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|     a5 --> a6: A transition | ||||
|  | ||||
| @@ -334,7 +335,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|    a7 --> a8: A transition | ||||
|  | ||||
| @@ -375,7 +376,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|  | ||||
|    stateDiagram-v2 | ||||
|        [*] --> test | ||||
| @@ -386,7 +387,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|        [*] --> test | ||||
|     test --> [*] | ||||
| @@ -396,7 +397,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|       [*] --> test | ||||
|     test --> [*] | ||||
| @@ -444,7 +445,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|  | ||||
|    stateDiagram-v2 | ||||
|        [*] --> First | ||||
| @@ -458,7 +459,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|        [*] --> First | ||||
|     state First { | ||||
| @@ -471,7 +472,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
| stateDiagram-v2 | ||||
|       [*] --> First | ||||
|     state First { | ||||
| @@ -546,7 +547,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|  | ||||
|    stateDiagram-v2 | ||||
|     [*] --> Level1 | ||||
| @@ -571,7 +572,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
|  stateDiagram-v2 | ||||
|     [*] --> Level1 | ||||
|  | ||||
| @@ -594,7 +595,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
|  stateDiagram-v2 | ||||
|     [*] --> Level1 | ||||
|  | ||||
| @@ -675,7 +676,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|  | ||||
|    stateDiagram-v2 | ||||
|    [*] --> B1 | ||||
| @@ -698,7 +699,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
|  stateDiagram-v2 | ||||
|   [*] --> B1 | ||||
|     B1 --> B2 | ||||
| @@ -721,7 +722,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
|  stateDiagram-v2 | ||||
| [*] --> B1 | ||||
|     B1 --> B2 | ||||
| @@ -783,7 +784,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|  | ||||
|    stateDiagram-v2 | ||||
|    state if_state <<choice>> | ||||
| @@ -795,7 +796,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
|  stateDiagram-v2 | ||||
|    state if_state <<choice>> | ||||
|     [*] --> IsPositive | ||||
| @@ -806,7 +807,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
|  stateDiagram-v2 | ||||
|  state if_state <<choice>> | ||||
|     [*] --> IsPositive | ||||
| @@ -864,7 +865,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|    stateDiagram-v2 | ||||
|     state fork_state <<fork>> | ||||
|       [*] --> fork_state | ||||
| @@ -881,7 +882,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
|    stateDiagram-v2 | ||||
|     state fork_state <<fork>> | ||||
|       [*] --> fork_state | ||||
| @@ -898,7 +899,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
|    stateDiagram-v2 | ||||
|     state fork_state <<fork>> | ||||
|       [*] --> fork_state | ||||
| @@ -954,7 +955,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|    stateDiagram-v2 | ||||
|      TN3: The state with a note | ||||
|         note right of TN3 | ||||
| @@ -967,7 +968,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
|    stateDiagram-v2 | ||||
|      TN5: The state with a note | ||||
|         note right of TN5 | ||||
| @@ -981,7 +982,7 @@ stateDiagram-v2 | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
|    stateDiagram-v2 | ||||
|      TN7: The state with a note | ||||
|         note right of TN7 | ||||
| @@ -1051,7 +1052,7 @@ state Active { | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|      stateDiagram-v2 | ||||
|     [*] --> Active | ||||
|  | ||||
| @@ -1072,7 +1073,7 @@ state Active { | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
|      stateDiagram-v2 | ||||
|     [*] --> Active | ||||
|  | ||||
| @@ -1094,7 +1095,7 @@ state Active { | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
|      stateDiagram-v2 | ||||
|     [*] --> Active | ||||
|  | ||||
| @@ -1158,7 +1159,7 @@ direction LR | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram2" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn"} }%% | ||||
| %%{init: {"look": "handDrawn"} }%% | ||||
|      stateDiagram-v2 | ||||
|    direction LR | ||||
|     [*] --> D1 | ||||
| @@ -1173,7 +1174,7 @@ direction LR | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram3" class="mermaid"> | ||||
| %%{init: {"handdrawn": false, "layout": "elk"} }%% | ||||
| %%{init: {"handDrawn": false, "layout": "elk"} }%% | ||||
|      stateDiagram-v2 | ||||
|     direction LR | ||||
|     [*] --> D1 | ||||
| @@ -1188,7 +1189,7 @@ direction LR | ||||
|       </td> | ||||
|       <td> | ||||
|         <pre id="diagram4" class="mermaid"> | ||||
| %%{init: {"look": "handdrawn", "layout": "elk"} }%% | ||||
| %%{init: {"look": "handDrawn", "layout": "elk"} }%% | ||||
|      stateDiagram-v2 | ||||
|     direction LR | ||||
|     [*] --> D1 | ||||
| @@ -1221,14 +1222,14 @@ direction LR | ||||
|  | ||||
|   <script type="module"> | ||||
|     import mermaid from './mermaid.esm.mjs'; | ||||
|     import { layouts } from './mermaid-layout-elk.esm.mjs'; | ||||
|     import layouts from './mermaid-layout-elk.esm.mjs'; | ||||
|     mermaid.registerLayoutLoaders(layouts); | ||||
|     mermaid.parseError = function (err, hash) { | ||||
|  | ||||
|     }; | ||||
|  | ||||
|     mermaid.initialize({ | ||||
|       handdrawn: false, | ||||
|       handDrawn: false, | ||||
|       mergeEdges: true, | ||||
|       layout: 'dagre', | ||||
|       flowchart: { titleTopMargin: 10 }, | ||||
| @@ -1253,7 +1254,7 @@ direction LR | ||||
|  | ||||
|     let coll = document.getElementsByClassName("collapsible"); | ||||
|     for (const element of coll) { | ||||
|   element.addEventListener("click", function () { | ||||
|       element.addEventListener("click", function () { | ||||
|         this.classList.toggle("active"); | ||||
|         let content = this.nextElementSibling; | ||||
|         if (content.style.maxHeight) { | ||||
| @@ -1267,4 +1268,4 @@ direction LR | ||||
|   </script> | ||||
| </body> | ||||
|  | ||||
| </html> | ||||
| </html> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import mermaid from './mermaid.esm.mjs'; | ||||
| import flowchartELK from './mermaid-flowchart-elk.esm.mjs'; | ||||
| import externalExample from './mermaid-example-diagram.esm.mjs'; | ||||
| import layouts from './mermaid-layout-elk.esm.mjs'; | ||||
| import zenUml from './mermaid-zenuml.esm.mjs'; | ||||
| import mermaid from './mermaid.esm.mjs'; | ||||
|  | ||||
| function b64ToUtf8(str) { | ||||
|   return decodeURIComponent(escape(window.atob(str))); | ||||
| @@ -46,8 +46,27 @@ const contentLoaded = async function () { | ||||
|       document.getElementsByTagName('body')[0].appendChild(div); | ||||
|     } | ||||
|  | ||||
|     await mermaid.registerExternalDiagrams([externalExample, zenUml, flowchartELK]); | ||||
|     await mermaid.registerExternalDiagrams([externalExample, zenUml]); | ||||
|  | ||||
|     mermaid.registerLayoutLoaders(layouts); | ||||
|     mermaid.initialize(graphObj.mermaid); | ||||
|     const staticBellIconPack = { | ||||
|       prefix: 'fa6-regular', | ||||
|       icons: { | ||||
|         bell: { | ||||
|           body: '<path fill="currentColor" d="M224 0c-17.7 0-32 14.3-32 32v19.2C119 66 64 130.6 64 208v25.4c0 45.4-15.5 89.5-43.8 124.9L5.3 377c-5.8 7.2-6.9 17.1-2.9 25.4S14.8 416 24 416h400c9.2 0 17.6-5.3 21.6-13.6s2.9-18.2-2.9-25.4l-14.9-18.6c-28.3-35.5-43.8-79.6-43.8-125V208c0-77.4-55-142-128-156.8V32c0-17.7-14.3-32-32-32m0 96c61.9 0 112 50.1 112 112v25.4c0 47.9 13.9 94.6 39.7 134.6H72.3c25.8-40 39.7-86.7 39.7-134.6V208c0-61.9 50.1-112 112-112m64 352H160c0 17 6.7 33.3 18.7 45.3S207 512 224 512s33.3-6.7 45.3-18.7S288 465 288 448"/>', | ||||
|           width: 448, | ||||
|         }, | ||||
|       }, | ||||
|       width: 512, | ||||
|       height: 512, | ||||
|     }; | ||||
|     mermaid.registerIconPacks([ | ||||
|       { | ||||
|         name: 'fa', | ||||
|         loader: () => staticBellIconPack, | ||||
|       }, | ||||
|     ]); | ||||
|     await mermaid.run(); | ||||
|   } | ||||
| }; | ||||
| @@ -132,7 +151,7 @@ if (typeof document !== 'undefined') { | ||||
|   window.addEventListener( | ||||
|     'load', | ||||
|     function () { | ||||
|       if (this.location.href.match('xss.html')) { | ||||
|       if (/xss.html/.exec(this.location.href)) { | ||||
|         this.console.log('Using api'); | ||||
|         void contentLoadedApi().finally(markRendered); | ||||
|       } else { | ||||
|   | ||||
| @@ -15,6 +15,7 @@ | ||||
|  | ||||
| import '@cypress/code-coverage/support'; | ||||
| import '@applitools/eyes-cypress/commands'; | ||||
| import '@argos-ci/cypress/support'; | ||||
| // Import commands.js using ES2015 syntax: | ||||
| import './commands'; | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|   "compilerOptions": { | ||||
|     "target": "es2020", | ||||
|     "lib": ["es2020", "dom"], | ||||
|     "types": ["cypress", "node"], | ||||
|     "types": ["cypress", "node", "@argos-ci/cypress/dist/support.d.ts"], | ||||
|     "allowImportingTsExtensions": true, | ||||
|     "noEmit": true | ||||
|   }, | ||||
|   | ||||
							
								
								
									
										256
									
								
								demos/architecture.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										256
									
								
								demos/architecture.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,256 @@ | ||||
| <!doctype html> | ||||
| <html lang="en"> | ||||
|   <head> | ||||
|     <meta charset="utf-8" /> | ||||
|     <meta http-equiv="X-UA-Compatible" content="IE=edge" /> | ||||
|     <title>Architecture Mermaid Quick Test Page</title> | ||||
|     <link rel="icon" type="image/png" href="data:image/png;base64,iVBORw0KGgo=" /> | ||||
|     <style> | ||||
|       div.mermaid { | ||||
|         /* font-family: 'trebuchet ms', verdana, arial; */ | ||||
|         font-family: 'Courier New', Courier, monospace !important; | ||||
|       } | ||||
|     </style> | ||||
|   </head> | ||||
|  | ||||
|   <body> | ||||
|     <h1>Architecture diagram demo</h1> | ||||
|     <h2>Simple diagram with groups</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         group api(cloud)[API] | ||||
|  | ||||
|         service db(database)[Database] in api | ||||
|         service disk1(disk)[Storage] in api | ||||
|         service disk2(disk)[Storage] in api | ||||
|         service server(server)[Server] in api | ||||
|         service gateway(internet)[Gateway]  | ||||
|  | ||||
|         db:L -- R:server | ||||
|         disk1:T -- B:server | ||||
|         disk2:T -- B:db | ||||
|         server:T -- B:gateway | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>Groups within groups</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         group api[API] | ||||
|         group public[Public API] in api | ||||
|         group private[Private API] in api | ||||
|  | ||||
|  | ||||
|         service serv1(server)[Server] in public | ||||
|  | ||||
|  | ||||
|         service serv2(server)[Server] in private | ||||
|         service db(database)[Database] in private | ||||
|  | ||||
|         service gateway(internet)[Gateway] in api | ||||
|  | ||||
|         serv1:B -- T:serv2 | ||||
|  | ||||
|         serv2:L -- R:db | ||||
|  | ||||
|         serv1:L -- R:gateway | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>Default icon (?) from unknown icon name</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         service unknown(iconnamedoesntexist)[Unknown Icon] | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>Split Direction</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         service db(database)[Database] | ||||
|         service s3(disk)[Storage] | ||||
|         service serv1(server)[Server 1] | ||||
|         service serv2(server)[Server 2] | ||||
|         service disk(disk)[Disk] | ||||
|  | ||||
|         db:L -- R:s3 | ||||
|         serv1:L -- T:s3 | ||||
|         serv2:L -- B:s3 | ||||
|         serv1:T -- B:disk | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>Arrow Tests</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         service servC(server)[Server 1] | ||||
|         service servL(server)[Server 2] | ||||
|         service servR(server)[Server 3] | ||||
|         service servT(server)[Server 4] | ||||
|         service servB(server)[Server 5] | ||||
|  | ||||
|         servC:L <--> R:servL | ||||
|         servC:R <--> L:servR | ||||
|         servC:T <--> B:servT | ||||
|         servC:B <--> T:servB | ||||
|  | ||||
|         servL:T <--> L:servT | ||||
|         servL:B <--> L:servB | ||||
|         servR:T <--> R:servT | ||||
|         servR:B <--> R:servB | ||||
|     </pre> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         service servC(server)[Server 1] | ||||
|         service servL(server)[Server 2] | ||||
|         service servR(server)[Server 3] | ||||
|         service servT(server)[Server 4] | ||||
|         service servB(server)[Server 5] | ||||
|  | ||||
|         servC:L <--> R:servL | ||||
|         servC:R <--> L:servR | ||||
|         servC:T <--> B:servT | ||||
|         servC:B <--> T:servB | ||||
|  | ||||
|         servT:L <--> T:servL | ||||
|         servB:L <--> B:servL | ||||
|         servT:R <--> T:servR | ||||
|         servB:R <--> B:servR | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>Group Edges</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         group left_group(cloud)[Left] | ||||
|         group right_group(cloud)[Right] | ||||
|         group top_group(cloud)[Top] | ||||
|         group bottom_group(cloud)[Bottom] | ||||
|         group center_group(cloud)[Center] | ||||
|  | ||||
|         service left_disk(disk)[Disk] in left_group | ||||
|         service right_disk(disk)[Disk] in right_group | ||||
|         service top_disk(disk)[Disk] in top_group | ||||
|         service bottom_disk(disk)[Disk] in bottom_group | ||||
|         service center_disk(disk)[Disk] in center_group | ||||
|  | ||||
|         left_disk{group}:R <--> L:center_disk{group} | ||||
|         right_disk{group}:L <--> R:center_disk{group} | ||||
|         top_disk{group}:B <--> T:center_disk{group} | ||||
|         bottom_disk{group}:T <--> B:center_disk{group} | ||||
|   </pre | ||||
|     > | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>Edge Label Test</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         service servC(server)[Server 1] | ||||
|         service servL(server)[Server 2] | ||||
|         service servR(server)[Server 3] | ||||
|         service servT(server)[Server 4] | ||||
|         service servB(server)[Server 5] | ||||
|  | ||||
|         servC:L -[Label]- R:servL | ||||
|         servC:R -[Label]- L:servR | ||||
|         servC:T -[Label]- B:servT | ||||
|         servC:B -[Label]- T:servB | ||||
|  | ||||
|         servL:T -[Label]- L:servT | ||||
|         servL:B -[Label]- L:servB | ||||
|         servR:T -[Label]- R:servT | ||||
|         servR:B -[Label]- R:servB | ||||
|     </pre> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         service servC(server)[Server 1] | ||||
|         service servL(server)[Server 2] | ||||
|         service servR(server)[Server 3] | ||||
|         service servT(server)[Server 4] | ||||
|         service servB(server)[Server 5] | ||||
|  | ||||
|         servC:L -[Label that is Long]- R:servL | ||||
|         servC:R -[Label that is Long]- L:servR | ||||
|         servC:T -[Label that is Long]- B:servT | ||||
|         servC:B -[Label that is Long]- T:servB | ||||
|  | ||||
|         servL:T -[Label that is Long]- L:servT | ||||
|         servL:B -[Label that is Long]- L:servB | ||||
|         servR:T -[Label that is Long]- R:servT | ||||
|         servR:B -[Label that is Long]- R:servB | ||||
|     </pre> | ||||
|  | ||||
|     <hr /> | ||||
|     <h2>Junction Demo</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         service left_disk(disk)[Disk] | ||||
|         service top_disk(disk)[Disk] | ||||
|         service bottom_disk(disk)[Disk] | ||||
|         service top_gateway(internet)[Gateway] | ||||
|         service bottom_gateway(internet)[Gateway] | ||||
|         junction juncC | ||||
|         junction juncR | ||||
|  | ||||
|         left_disk:R -- L:juncC | ||||
|         top_disk:B -- T:juncC | ||||
|         bottom_disk:T -- B:juncC | ||||
|         juncC:R -- L:juncR | ||||
|         top_gateway:B -- T:juncR | ||||
|         bottom_gateway:T -- B:juncR | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>Junction Demo Groups</h2> | ||||
|     <pre class="mermaid"> | ||||
|       architecture-beta | ||||
|         group left | ||||
|         group right | ||||
|         service left_disk(disk)[Disk] in left | ||||
|         service top_disk(disk)[Disk] in left | ||||
|         service bottom_disk(disk)[Disk] in left | ||||
|         service top_gateway(internet)[Gateway] in right | ||||
|         service bottom_gateway(internet)[Gateway] in right | ||||
|         junction juncC in left | ||||
|         junction juncR in right | ||||
|  | ||||
|         left_disk:R -- L:juncC | ||||
|         top_disk:B -- T:juncC | ||||
|         bottom_disk:T -- B:juncC | ||||
|  | ||||
|  | ||||
|         top_gateway:B <-- T:juncR | ||||
|         bottom_gateway:T <-- B:juncR | ||||
|  | ||||
|         juncC{group}:R --> L:juncR{group} | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <h2>External Icons Demo</h2> | ||||
|     <pre class="mermaid"> | ||||
|     architecture-beta | ||||
|       service s3(logos:aws-s3)[Cloud Store] | ||||
|       service ec2(logos:aws-ec2)[Server] | ||||
|       service api(logos:aws-api-gateway)[Api Gateway] | ||||
|       service fa(fa:image)[Font Awesome Icon] | ||||
|     </pre> | ||||
|  | ||||
|     <script type="module"> | ||||
|       import mermaid from './mermaid.esm.mjs'; | ||||
|       mermaid.registerIconPacks([ | ||||
|         { | ||||
|           name: 'logos', | ||||
|           loader: () => | ||||
|             fetch('https://unpkg.com/@iconify-json/logos/icons.json').then((res) => res.json()), | ||||
|         }, | ||||
|         { | ||||
|           name: 'fa', | ||||
|           loader: () => | ||||
|             fetch('https://unpkg.com/@iconify-json/fa6-regular/icons.json').then((res) => | ||||
|               res.json() | ||||
|             ), | ||||
|         }, | ||||
|       ]); | ||||
|     </script> | ||||
|   </body> | ||||
| </html> | ||||
| @@ -159,30 +159,87 @@ | ||||
|       class People List~List~Person~~ | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <pre class="mermaid"> | ||||
|     classDiagram | ||||
|       A1 --> B1 | ||||
|       namespace A { | ||||
|         class A1 { | ||||
|           +foo : string | ||||
|         } | ||||
|         class A2 { | ||||
|           +bar : int | ||||
|       namespace Company.Project.Module { | ||||
|         class GenericClass~T~ { | ||||
|           +addItem(item: T) | ||||
|           +getItem() T | ||||
|         } | ||||
|       } | ||||
|       namespace B { | ||||
|         class B1 { | ||||
|           +foo : bool | ||||
|         } | ||||
|         class B2 { | ||||
|           +bar : float | ||||
|         } | ||||
|       } | ||||
|       A2 --> B2 | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <pre class="mermaid"> | ||||
|     classDiagram | ||||
|       namespace Company.Project.Module.SubModule { | ||||
|         class Report { | ||||
|           +generatePDF(data: List) | ||||
|           +generateCSV(data: List) | ||||
|         } | ||||
|       } | ||||
|       namespace Company.Project.Module { | ||||
|         class Admin { | ||||
|           +generateReport() | ||||
|         } | ||||
|       } | ||||
|       Admin --> Report : generates | ||||
|     </pre> | ||||
|     <pre class="mermaid"> | ||||
|     classDiagram | ||||
|       namespace Company.Project.Module { | ||||
|         class User { | ||||
|           +login(username: String, password: String) | ||||
|           +logout() | ||||
|         } | ||||
|         class Admin { | ||||
|           +addUser(user: User) | ||||
|           +removeUser(user: User) | ||||
|           +generateReport() | ||||
|         } | ||||
|         class Report { | ||||
|           +generatePDF(reportData: List) | ||||
|           +generateCSV(reportData: List) | ||||
|         } | ||||
|       } | ||||
|       Admin --> User : manages | ||||
|       Admin --> Report : generates | ||||
|     </pre> | ||||
|     <hr /> | ||||
|     <pre class="mermaid"> | ||||
|     classDiagram | ||||
|       namespace Shapes { | ||||
|         class Shape { | ||||
|           +calculateArea() double | ||||
|         } | ||||
|         class Circle { | ||||
|           +double radius | ||||
|         } | ||||
|         class Square { | ||||
|           +double side | ||||
|         } | ||||
|       } | ||||
|        | ||||
|       Shape <|-- Circle | ||||
|       Shape <|-- Square | ||||
|        | ||||
|       namespace Vehicles { | ||||
|         class Vehicle { | ||||
|           +String brand | ||||
|         } | ||||
|         class Car { | ||||
|           +int horsepower | ||||
|         } | ||||
|         class Bike { | ||||
|           +boolean hasGears | ||||
|         } | ||||
|       } | ||||
|        | ||||
|       Vehicle <|-- Car | ||||
|       Vehicle <|-- Bike | ||||
|       Car --> Circle : "Logo Shape" | ||||
|       Bike --> Square : "Logo Shape" | ||||
|                    | ||||
|     </pre> | ||||
|     <script type="module"> | ||||
|       import mermaid from './mermaid.esm.mjs'; | ||||
|       mermaid.initialize({ | ||||
|   | ||||
| @@ -125,6 +125,35 @@ | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <pre class="mermaid"> | ||||
|     erDiagram | ||||
|       p[Person] { | ||||
|           string firstName | ||||
|           string lastName | ||||
|       } | ||||
|       a["Customer Account"] { | ||||
|           string email | ||||
|       } | ||||
|  | ||||
|       b["Customer Account Secondary"] { | ||||
|         string email | ||||
|       } | ||||
|        | ||||
|       c["Customer Account Tertiary"] { | ||||
|         string email | ||||
|       } | ||||
|        | ||||
|       d["Customer Account Nth"] { | ||||
|         string email | ||||
|       } | ||||
|  | ||||
|       p ||--o| a : "has<br />one" | ||||
|       p ||--o| b : "has<br />one<br />two" | ||||
|       p ||--o| c : "has<br />one<br />two<br />three" | ||||
|       p ||--o| d : "has<br />one<br />two<br />three<br />...<br />Nth" | ||||
|     </pre> | ||||
|     <hr /> | ||||
|  | ||||
|     <pre class="mermaid"> | ||||
|     erDiagram | ||||
|       _customer_order { | ||||
|   | ||||
| @@ -88,6 +88,9 @@ | ||||
|       <li> | ||||
|         <h2><a href="./block.html">Layered Blocks</a></h2> | ||||
|       </li> | ||||
|       <li> | ||||
|         <h2><a href="./architecture.html">Architecture</a></h2> | ||||
|       </li> | ||||
|     </ul> | ||||
|   </body> | ||||
| </html> | ||||
|   | ||||
| @@ -238,6 +238,17 @@ | ||||
|       Alice-xJohn: Hello John, how are you? | ||||
|       John--xAlice: Great! | ||||
|     </pre> | ||||
|  | ||||
|     <hr /> | ||||
|  | ||||
|     <pre class="mermaid"> | ||||
|     sequenceDiagram | ||||
|       participant Alice | ||||
|       participant Bob | ||||
|       Alice<<->>Bob: Hello! | ||||
|       Alice<<->>Bob: Wow, we said that at the same time! | ||||
|       Bob<<-->>Alice: Bidirectional Arrows are so cool | ||||
|     </pre> | ||||
|     <script type="module"> | ||||
|       import mermaid from './mermaid.esm.mjs'; | ||||
|       mermaid.initialize({ | ||||
|   | ||||
| @@ -1,4 +1,3 @@ | ||||
| version: '3.9' | ||||
| services: | ||||
|   mermaid: | ||||
|     build: | ||||
| @@ -8,14 +7,12 @@ services: | ||||
|     tty: true | ||||
|     working_dir: /mermaid | ||||
|     mem_limit: '8G' | ||||
|     entrypoint: docker-entrypoint.sh | ||||
|     environment: | ||||
|       - NODE_OPTIONS=--max_old_space_size=8192 | ||||
|     volumes: | ||||
|       - ./:/mermaid | ||||
|       - root_cache:/root/.cache | ||||
|       - root_local:/root/.local | ||||
|       - root_npm:/root/.npm | ||||
|       - /tmp:/tmp | ||||
|     ports: | ||||
|       - 9000:9000 | ||||
|       - 3333:3333 | ||||
|   | ||||
| @@ -1,3 +0,0 @@ | ||||
| #!/bin/sh | ||||
| source /root/.shrc | ||||
| exec "$@" | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user