mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-26 08:24:07 +01:00 
			
		
		
		
	Compare commits
	
		
			1068 Commits
		
	
	
		
			v11.0.0
			...
			sidv/token
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 3b92f979e3 | ||
|   | c5843bee23 | ||
|   | ada42b892c | ||
|   | a19b42f3c2 | ||
|   | 9f90f4f23a | ||
|   | 348401c4f4 | ||
|   | 8145199203 | ||
|   | f408e938d4 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | af6e2b4cb6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7a4a52b50a | ||
|   | ee05d8588f | ||
|   | 58175f647e | ||
|   | d07f85e6ac | ||
|   | a79c0f4c00 | ||
|   | 4a19740aea | ||
|   | d155e414a0 | ||
|   | 8dd0e7a794 | ||
|   | 5e9c887385 | ||
|   | fdb8ae5b53 | ||
|   | e2de55202f | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | b4043840ca | ||
|   | 8f3e17e386 | ||
|   | 4e950e7256 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | de3e381ccf | ||
|   | b2fde76753 | ||
|   | b5587d8b87 | ||
|   | 9b75aeb224 | ||
|   | 993858cdc8 | ||
|   | f4e1f07412 | ||
|   | 09e0de6053 | ||
|   | 9a50bf5237 | ||
|   | 5747009c8f | ||
|   | dc513ec211 | ||
|   | 5f58d4f7b0 | ||
|   | 3536ceb5d3 | ||
|   | 7ed33a91c0 | ||
|   | f8bf03d365 | ||
|   | 4202ee521a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0e25fd42f9 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | feee5d1c8c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ab6d92c544 | ||
|   | d27d4abab7 | ||
|   | 3162cff7a9 | ||
|   | 9681a27b31 | ||
|   | ba534985ec | ||
|   | edc1ae1e0c | ||
|   | c00f3fb090 | ||
|   | 74a56fc58a | ||
|   | 08ffbb61e9 | ||
|   | 232e60c8cb | ||
|   | cd9ca76e39 | ||
|   | c13d988392 | ||
|   | 15ffe2021a | ||
|   | 4fbc19e0d7 | ||
|   | 2b8998fdd1 | ||
|   | 202ef31071 | ||
|   | b09f2e836a | ||
|   | 6a814a0d91 | ||
|   | b07bb9b3ff | ||
|   | 5120ed09ab | ||
|   | 61f3fc5ede | ||
|   | 90bbf90a83 | ||
|   | 92efc24283 | ||
|   | 1c45df4567 | ||
|   | 1575a93136 | ||
|   | bde653b1c2 | ||
|   | e9e663ffa3 | ||
|   | 963efa64c7 | ||
|   | e2e5101005 | ||
|   | 6ea13cded3 | ||
|   | c063b92cc9 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 304f133227 | ||
|   | 54a0dd0af6 | ||
|   | ab5b7694c6 | ||
|   | eb76dfb1ca | ||
|   | 28d7ec092c | ||
|   | 84b03f3a08 | ||
|   | f9ac9867c1 | ||
|   | ee6fb83265 | ||
|   | 46c16c963b | ||
|   | 32a68d489e | ||
|   | 7bbebff583 | ||
|   | c432aec2f6 | ||
|   | 64237fbaa7 | ||
|   | 7ba415dad1 | ||
|   | 7f47678862 | ||
|   | 127bac1147 | ||
|   | 9a90d795ca | ||
|   | f7fe8f2f59 | ||
|   | 1d9c2aab8d | ||
|   | 8fba9c1236 | ||
|   | 04800ff677 | ||
|   | 0f08c3bc9c | ||
|   | 7809b5a93f | ||
|   | ef9bb53e67 | ||
|   | 3e32332814 | ||
|   | e1aab25144 | ||
|   | c8697301ee | ||
|   | fcb1de915b | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | e345294658 | ||
|   | 9936099e25 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | e70b069576 | ||
|   | 28bab4a323 | ||
|   | 6cc31b7453 | ||
|   | 29ca1504dd | ||
|   | 16d2251e43 | ||
|   | bc2cc61240 | ||
|   | 6836e9c7a8 | ||
|   | 8dc016e7f9 | ||
|   | 3cad7984a3 | ||
|   | f5bae98098 | ||
|   | 0695893e30 | ||
|   | 9ef6090c8c | ||
|   | ec0d9c389a | ||
|   | 323b07a2e4 | ||
|   | c153d0455f | ||
|   | 9b00f1f2fb | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | a055ff7db3 | ||
|   | d032723a47 | ||
|   | daf83f596d | ||
|   | df636c6d0a | ||
|   | 64554a6c60 | ||
|   | becadf0a7d | ||
|   | 54d485f173 | ||
|   | b4f5b8ddaf | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | cb5c1ae367 | ||
|   | b29081d4e8 | ||
|   | 654097c438 | ||
|   | 1e672868c4 | ||
|   | bff32827b5 | ||
|   | 65f9b29b86 | ||
|   | 9868f3a4c3 | ||
|   | b4879d13b8 | ||
|   | 95964b5487 | ||
|   | 4e17da0a30 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | d8bf155f0e | ||
|   | 0b4f85230a | ||
|   | 0dff4ca438 | ||
|   | cc29437ede | ||
|   | dfaaf361f3 | ||
|   | 37538310d3 | ||
|   | c7ae08abc3 | ||
|   | 69973eaa02 | ||
|   | d3b2c7ea18 | ||
|   | 68f41f685d | ||
|   | 255279eb22 | ||
|   | fe3cffbb67 | ||
|   | 2a91849a38 | ||
|   | 082de76eef | ||
|   | 570ae78b15 | ||
|   | 885ac6f947 | ||
|   | 8328f74751 | ||
|   | 01b5079562 | ||
|   | 6b23647bec | ||
|   | 193fdb225e | ||
|   | c8ce416aba | ||
|   | 1388662132 | ||
|   | 757627427b | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 7cbd80af33 | ||
|   | 16c448b89b | ||
|   | c218e365bd | ||
|   | f507dbbe00 | ||
|   | 9966beb99b | ||
|   | f4713332c0 | ||
|   | 63ff5b1d98 | ||
|   | cb0a4703bd | ||
|   | 7e71b85668 | ||
|   | 1dd7bcb0a6 | ||
|   | bbf6ab1206 | ||
|   | 56f522ec50 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | d4e5acc530 | ||
|   | ef9cbb61e5 | ||
|   | 8a0ecc1fe9 | ||
|   | c6e1271ef7 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | b02294376a | ||
|   | 97c61d818c | ||
|   | 1c66237fa8 | ||
|   | 8ef5d324fd | ||
|   | c1ca3511c4 | ||
|   | 953d288957 | ||
|   | 143806b360 | ||
|   | a381ab6c41 | ||
|   | 93e20fdaa3 | ||
|   | ece3b254db | ||
|   | dd42305e8c | ||
|   | c34fd152d5 | ||
|   | 8f0e0b9c39 | ||
|   | fe8932e906 | ||
|   | 73bbde8476 | ||
|   | 01a41ef530 | ||
|   | 124d2f72dd | ||
|   | 34e8946c58 | ||
|   | 0197c08916 | ||
|   | ef30283fe9 | ||
|   | dffaf9fa8f | ||
|   | 9168d5d1f4 | ||
|   | f33ebfaf7a | ||
|   | 054f929150 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 8cb1c68166 | ||
|   | d752240efc | ||
|   | 8d0902de4c | ||
|   | f6c32b6da4 | ||
|   | bdf145ffe3 | ||
|   | 75ca802b62 | ||
|   | 3f85b6179d | ||
|   | b315d70af5 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 848be3d129 | ||
|   | 5fabd414fb | ||
|   | 17e2f9e0d4 | ||
|   | 7fa8b35bdc | ||
|   | e6ea4eae50 | ||
|   | 7401cb8f6a | ||
|   | e765007b21 | ||
|   | b5cd101d86 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | da12ace593 | ||
|   | 2c676b6222 | ||
|   | 0af08276d2 | ||
|   | d790e353b0 | ||
|   | e07e9b9daf | ||
|   | 948ec4d1ce | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | e62d268c89 | ||
|   | 742ad7c130 | ||
|   | 56cc3728c5 | ||
|   | fb86e5c689 | ||
|   | f8746bee04 | ||
|   | bb97fdbd1e | ||
|   | e3ec6ed993 | ||
|   | 6df1fa1a03 | ||
|   | fd6b875f87 | ||
|   | be3da0b39d | ||
|   | 64bc7f4bd9 | ||
|   | 75e796f183 | ||
|   | 6cc0132e0a | ||
|   | 4bc70b7325 | ||
|   | bfdd0f244d | ||
|   | 0e819ae050 | ||
|   | 10f11e016f | ||
|   | b7d66bb975 | ||
|   | 74695d2e88 | ||
|   | 38eed7c988 | ||
|   | d16e46a386 | ||
|   | 97820a50c2 | ||
|   | df948bcf2c | ||
|   | cfd097b029 | ||
|   | ffc1fef599 | ||
|   | 1e8e4e4b73 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 606ecf8990 | ||
|   | 16a5fc05d6 | ||
|   | 62fd359c0e | ||
|   | b0f4ace3a1 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 6f506c30eb | ||
|   | cf2c7f7f8c | ||
|   | 6041729ae2 | ||
|   | b7ef8b2b5a | ||
|   | bfea287b44 | ||
|   | 9afb181d06 | ||
|   | cfe7cce41d | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 33029c8bd2 | ||
|   | e54d10c706 | ||
|   | 86c7532f46 | ||
|   | 8aa87c7091 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | e1024838e8 | ||
|   | 4cce43f0a1 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | c69ab34eac | ||
|   | 7353be3b16 | ||
|   | 02be63ed72 | ||
|   | 742531a2c2 | ||
|   | 991d403d7f | ||
|   | 290c678dc7 | ||
|   | 2c31a599af | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 2655be0bad | ||
|   | 4f97c8c70e | ||
|   | f85977246c | ||
|   | a4fd42214b | ||
|   | ca885027d4 | ||
|   | 9f6f1e96e5 | ||
|   | 351ce30d8a | ||
|   | 2933eb5c28 | ||
|   | 09ecf76034 | ||
|   | 2b86750cb3 | ||
|   | b45224755e | ||
|   | 14524e1b0e | ||
|   | efa47e3176 | ||
|   | 1bc45405e0 | ||
|   | 3720e1a894 | ||
|   | 76138cf3b9 | ||
|   | 2506c29f6b | ||
|   | 463ba6ed6d | ||
|   | 17b783135f | ||
|   | 8df2729bd4 | ||
|   | a001619464 | ||
|   | 3c5a19d297 | ||
|   | a98290a6e2 | ||
|   | 9bac464442 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 11fb806992 | ||
|   | d424a4473a | ||
|   | 4062813d44 | ||
|   | 29b9d3069b | ||
|   | c38d9a6620 | ||
|   | 2f65429aa4 | ||
|   | c24028f2a4 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | a20c292653 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1c6304b3fb | ||
|   | 3ac93af80c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ce586e1b31 | ||
|   | 926f97124b | ||
|   | 0f2301f2d6 | ||
|   | 58e8f65135 | ||
|   | 1b51fbfcca | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1296840696 | ||
|   | f99e2c9366 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c71b56ebe3 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9904afce64 | ||
|   | a827fb1202 | ||
|   | 51be99c9de | ||
|   | b83b778f2a | ||
|   | 86a91597f9 | ||
|   | 1b12ac133e | ||
|   | e55880a9c4 | ||
|   | 9cc309b69c | ||
|   | d3308232e8 | ||
|   | 0b8f27e1d2 | ||
|   | 93f2c241b8 | ||
|   | fb44e769f2 | ||
|   | fabdfd9ae8 | ||
|   | 72d60d2633 | ||
|   | 2d7686eb65 | ||
|   | d9a26ff193 | ||
|   | 2401eea725 | ||
|   | ddf18dd233 | ||
|   | 4b98dabc3f | ||
|   | 5a3e0ccc3d | ||
|   | 38a3ad3370 | ||
|   | b777c12094 | ||
|   | 8fc36d2684 | ||
|   | e2474049d8 | ||
|   | 6e0fe03552 | ||
|   | cda48a7143 | ||
|   | e5a28de26e | ||
|   | 0ae4f97036 | ||
|   | 218bfe1603 | ||
|   | 339c670839 | ||
|   | c5a19f6e85 | ||
|   | be57484573 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 0cb88c21dc | ||
|   | 0bc1f5296f | ||
|   | 4776f97f82 | ||
|   | 460db0aea7 | ||
|   | 02cf111995 | ||
|   | 14d9d92112 | ||
|   | fce77a19b0 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 719685b930 | ||
|   | 0cbc000bfa | ||
|   | 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 | ||
|   | 91e3da1293 | ||
|   | fa46267c14 | ||
|   | dc7e32eb10 | ||
|   | 10679297f9 | ||
|   | 3e697e2ea4 | ||
|   | 6a649d347d | ||
|   | fd372941c7 | ||
|   | 1c8c95367d | ||
|   | f031abcec2 | ||
|   | dd62322ae5 | ||
|   | 48e5dee963 | ||
|   | b3dfc60fff | ||
|   | bb3b95f0bd | ||
|   | 4fc9028dc1 | ||
|   | 02cadd87ff | ||
|   | 1c105154a6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | daaeded0b5 | ||
|   | ed7d41a3cb | ||
|   | f052a3f686 | ||
|   | 11da07b735 | ||
|   | d01e180caf | ||
|   | 4c400966b4 | ||
|   | bd0a00d373 | ||
|   | 3b8bd6b979 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | f849c36942 | ||
|   | c83fc753a1 | ||
|   | eeeb5fcdd9 | ||
|   | 41f22864b4 | ||
|   | 6a99a1a40a | ||
|   | 1fcebab9ed | ||
|   | bed301a485 | ||
|   | 31546b08ff | ||
|   | 25337dc453 | ||
|   | cb85d50f61 | ||
|   | a52949318a | ||
|   | 745495c2d5 | ||
|   | dd261a54df | ||
|   | 94d2a0ee89 | ||
|   | f035db2feb | ||
|   | b105c7b35e | ||
|   | 149f991c1d | ||
|   | a43ee60942 | ||
|   | 5f11cd417f | ||
|   | 3782b69744 | ||
|   | ca93280b17 | ||
|   | 2ec9f0af2e | ||
|   | 3eb338df04 | ||
|   | b7790ba6b5 | ||
|   | b67c931f18 | ||
|   | 97186504b5 | ||
|   | bd4ca9af1b | ||
|   | 9ac20a5cb8 | ||
|   | 20a58d6dbb | ||
|   | 191e4217fc | ||
|   | 8745daa701 | ||
|   | 27f7b615cc | ||
|   | e3c426de86 | ||
|   | 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 | ||
|   | db1db1ab0e | ||
|   | cec28464ec | ||
|   | a2fba0284e | ||
|   | f424a51133 | ||
|   | 46b8faddae | ||
|   | ad12fa7fff | ||
|   | 19cce07ab5 | ||
|   | 439dcb10b2 | ||
|   | 98cb8b998e | ||
|   | 1654a4b01c | ||
|   | 8e72611922 | ||
|   | a857d3807f | ||
|   | 3dc0af3159 | ||
|   | abf7ecd2ca | ||
|   | 9c032648c1 | ||
|   | 9dcda25355 | ||
|   | 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 | ||
|   | c61159b63f | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 7a1c25bb3b | ||
|   | d0ea3dd82b | ||
|   | 36444ab242 | ||
|   | 0cf639cb1b | ||
|   | 90364a020b | ||
|   | 6e4b349c3a | ||
|   | 03d6531a7d | ||
|   | dd5866a4cb | ||
|   | 52f5d95c81 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 792a62438f | ||
|   | 73e16d0857 | ||
|   | 4e8a7e0b4c | ||
|   | 121e27e850 | ||
|   | 3eaf8b7177 | ||
|   | 0152ed7027 | ||
|   | f233bfd75e | ||
|   | 4298a57297 | ||
|   | 6e8ea148bc | ||
|   | 777522e8d5 | ||
|   | a4007ffb80 | ||
|   | de875c9e27 | ||
|   | 3cfcb2da41 | ||
|   | 24ba5b73da | ||
|   | 8ef30a2642 | ||
|   | 4c3db653f5 | ||
|   | 90b7a3be63 | ||
|   | 3ac242978d | ||
|   | 94ee076aad | ||
|   | 7a7b41557d | ||
|   | d9d9cc9ddc | ||
|   | 0fbe5f2f10 | ||
|   | 4ec0dcfe1f | ||
|   | 36f2989249 | ||
|   | 99956b4283 | ||
|   | b93691be0e | ||
|   | 66e53df04b | ||
|   | 95c483934d | ||
|   | 9c5a8f7ef1 | ||
|   | e2f3041aa2 | ||
|   | 9926ae4e74 | ||
|   | 58463b5e80 | ||
|   | 7b51327b24 | ||
|   | 06dd350aab | ||
|   | 4f2085765d | ||
|   | eceae9b64c | ||
|   | 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 | ||
|   | c673cf22bd | ||
|   | 4d401c127d | ||
|   | 3c119e4a52 | ||
|   | 303a160359 | ||
|   | 731b330e40 | ||
|   | 261aea3089 | ||
|   | 3cd5244949 | ||
|   | 31b8707819 | ||
|   | a0893b8e6c | ||
|   | 73aae9e86e | ||
|   | e1c8eb8a72 | ||
|   | bc546ef562 | ||
|   | 251b94647b | ||
|   | 4aeb2ae9a2 | ||
|   | d73a090875 | ||
|   | aba306b685 | ||
|   | c49a1bf60c | ||
|   | d684e0d924 | ||
|   | 269284c6d7 | ||
|   | 62950c31a4 | ||
|   | e0d0cdcf1f | ||
|   | a93b8324ad | ||
|   | 0f635ed344 | ||
|   | efe6affe64 | ||
|   | f140d1ab45 | ||
|   | 89e4de1dd0 | ||
|   | ac48f01e25 | ||
|   | 2218929416 | ||
|   | 00603e7bac | ||
|   | 4c48b8cc54 | ||
|   | b807e330c8 | ||
|   | 04b15e7ece | ||
|   | 575c39e8a5 | ||
|   | 8fe0ed1d03 | ||
|   | 38e048b94e | ||
|   | 2a38d46fd9 | ||
|   | 9ed38ccf3a | ||
|   | 933f3f391c | ||
|   | cfb5b88ee6 | ||
|   | 9cd44eb92c | ||
|   | d0942d4897 | ||
|   | 3d789a0675 | ||
|   | 1d3f214109 | ||
|   | e51077c765 | ||
|   | 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 | ||
|   | 880c4d4ed6 | ||
|   | 2ae2686e34 | ||
|   | 25609d69c4 | ||
|   | 4d8e519298 | ||
|   | 6f7c291512 | ||
|   | 1d0e98dd62 | ||
|   | 958204e831 | ||
|   | 82c247bb11 | ||
|   | 2a56b640c0 | ||
|   | eae67a9696 | ||
|   | 33da2b4057 | ||
| ![autofix-ci[bot]](/assets/img/avatar_default.png)  | 8fe2d7c2e6 | ||
|   | e099e7d220 | ||
|   | 7c1cb236a6 | ||
|   | d9b16953f0 | ||
|   | 78dfffa1a7 | ||
|   | ce2f834683 | ||
|   | 4d6b92e5bf | ||
|   | 1b128cae77 | ||
|   | a94fe811dd | ||
|   | bde35b23f7 | ||
|   | 3f039562b9 | ||
|   | a4cf503071 | ||
|   | 2315d3c90a | ||
|   | e9ca618780 | ||
|   | 7c9e0e51da | ||
|   | 769d5660f5 | ||
|   | b09dc5db67 | ||
|   | 0049127bb7 | ||
|   | 5b6c95cea3 | ||
|   | 48e6901936 | ||
|   | 734bde3877 | ||
|   | cabb7b65e9 | ||
|   | b21fc9fe22 | ||
|   | 634b00b379 | ||
|   | b28f9f8136 | ||
|   | ac7891c14b | ||
|   | 2dfadca14c | ||
|   | 84f1d82aac | ||
|   | 1d27fac4d9 | ||
|   | a5d3164ea4 | ||
|   | cb302a08b8 | ||
|   | 497712a3fa | ||
|   | 073175e5f7 | ||
|   | 6bd1da219a | ||
|   | 0a14f2cffc | ||
|   | dcb1b4871f | ||
|   | baa6c9e4b9 | ||
|   | 251e808a29 | ||
|   | 22c0090979 | ||
|   | aef991bc49 | ||
|   | 6d5791a63a | ||
|   | 2709c2d2e1 | ||
|   | 92d819ede5 | ||
|   | 36f52be3bf | ||
|   | f47bbee24a | ||
|   | 361e25ba34 | ||
|   | 46a37a6eea | ||
|   | b911bd3e42 | ||
|   | 10682ef31f | ||
|   | 0ab7a3d8ec | ||
|   | a493e2fbb3 | ||
|   | 5e214877a4 | ||
|   | 84bd20b04b | ||
|   | 6c6ce28f7d | ||
|   | e01acec12b | ||
|   | cc22e13e71 | ||
|   | 346ae22108 | ||
|   | 5a4d4972e2 | ||
|   | 03bbfa0b94 | 
| @@ -1,3 +1,9 @@ | |||||||
|  | export interface PackageOptions { | ||||||
|  |   name: string; | ||||||
|  |   packageName: string; | ||||||
|  |   file: string; | ||||||
|  | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Shared common options for both ESBuild and Vite |  * Shared common options for both ESBuild and Vite | ||||||
|  */ |  */ | ||||||
| @@ -27,4 +33,4 @@ export const packageOptions = { | |||||||
|     packageName: 'mermaid-layout-elk', |     packageName: 'mermaid-layout-elk', | ||||||
|     file: 'layouts.ts', |     file: 'layouts.ts', | ||||||
|   }, |   }, | ||||||
| } as const; | } as const satisfies Record<string, PackageOptions>; | ||||||
|   | |||||||
| @@ -19,12 +19,14 @@ const MERMAID_CONFIG_DIAGRAM_KEYS = [ | |||||||
|   'xyChart', |   'xyChart', | ||||||
|   'requirement', |   'requirement', | ||||||
|   'mindmap', |   'mindmap', | ||||||
|  |   'kanban', | ||||||
|   'timeline', |   'timeline', | ||||||
|   'gitGraph', |   'gitGraph', | ||||||
|   'c4', |   'c4', | ||||||
|   'sankey', |   'sankey', | ||||||
|   'block', |   'block', | ||||||
|   'packet', |   'packet', | ||||||
|  |   'architecture', | ||||||
| ] as const; | ] as const; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|   | |||||||
							
								
								
									
										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) | ||||||
							
								
								
									
										5
									
								
								.changeset/angry-bags-brake.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/angry-bags-brake.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | fix: architecture diagrams no longer grow to extreme heights due to conflicting alignments | ||||||
							
								
								
									
										5
									
								
								.changeset/bright-ads-exist.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/bright-ads-exist.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Fixes for consistent edge id creation & handling edge cases for animate edge feature | ||||||
							
								
								
									
										5
									
								
								.changeset/chatty-elephants-warn.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/chatty-elephants-warn.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Fix for issue #6195 - allowing @ signs inside node labels | ||||||
							
								
								
									
										5
									
								
								.changeset/chilly-years-cheat.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/chilly-years-cheat.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | fix: `mermaidAPI.getDiagramFromText()` now returns a new different db for each class diagram | ||||||
							
								
								
									
										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"] | ||||||
|  | } | ||||||
							
								
								
									
										5
									
								
								.changeset/dull-tips-cough.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/dull-tips-cough.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | fix: revert state db to resolve getData returning empty nodes and edges | ||||||
							
								
								
									
										8
									
								
								.changeset/great-ghosts-rule.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.changeset/great-ghosts-rule.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': minor | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Flowchart new syntax for node metadata bugs | ||||||
|  |  | ||||||
|  | - Incorrect label mapping for nodes when using `&` | ||||||
|  | - Syntax error when `}` with trailing spaces before new line | ||||||
							
								
								
									
										5
									
								
								.changeset/many-brooms-promise.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/many-brooms-promise.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': minor | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Adding support for animation of flowchart edges | ||||||
							
								
								
									
										5
									
								
								.changeset/new-kiwis-listen.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/new-kiwis-listen.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | fix: `mermaidAPI.getDiagramFromText()` now returns a new different db for each flowchart | ||||||
							
								
								
									
										5
									
								
								.changeset/stupid-dots-do.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/stupid-dots-do.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | fix: Gantt, Sankey and User Journey diagram are now able to pick font-family from mermaid config. | ||||||
							
								
								
									
										5
									
								
								.changeset/witty-crews-smell.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/witty-crews-smell.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | --- | ||||||
|  | 'mermaid': patch | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | `mermaidAPI.getDiagramFromText()` now returns a new different db for each state diagram | ||||||
| @@ -26,6 +26,7 @@ concat | |||||||
| controlx | controlx | ||||||
| controly | controly | ||||||
| CSSCLASS | CSSCLASS | ||||||
|  | curv | ||||||
| CYLINDEREND | CYLINDEREND | ||||||
| CYLINDERSTART | CYLINDERSTART | ||||||
| DAGA | DAGA | ||||||
| @@ -55,6 +56,7 @@ GENERICTYPE | |||||||
| getBoundarys | getBoundarys | ||||||
| grammr | grammr | ||||||
| graphtype | graphtype | ||||||
|  | halign | ||||||
| iife | iife | ||||||
| interp | interp | ||||||
| introdcued | introdcued | ||||||
| @@ -66,6 +68,7 @@ Kaufmann | |||||||
| keyify | keyify | ||||||
| LABELPOS | LABELPOS | ||||||
| LABELTYPE | LABELTYPE | ||||||
|  | layoutstop | ||||||
| lcov | lcov | ||||||
| LEFTOF | LEFTOF | ||||||
| Lexa | Lexa | ||||||
| @@ -138,6 +141,7 @@ tsdoc | |||||||
| typeof | typeof | ||||||
| typestr | typestr | ||||||
| unshift | unshift | ||||||
|  | urlsafe | ||||||
| verifymethod | verifymethod | ||||||
| VERIFYMTHD | VERIFYMTHD | ||||||
| WARN_DOCSDIR_DOESNT_MATCH | WARN_DOCSDIR_DOESNT_MATCH | ||||||
|   | |||||||
| @@ -28,6 +28,9 @@ dictionaryDefinitions: | |||||||
|   - name: suggestions |   - name: suggestions | ||||||
|     words: |     words: | ||||||
|       - none |       - none | ||||||
|  |       - disp | ||||||
|  |       - subproc | ||||||
|  |       - tria | ||||||
|     suggestWords: |     suggestWords: | ||||||
|       - seperator:separator |       - seperator:separator | ||||||
|       - vertice:vertex |       - vertice:vertex | ||||||
|   | |||||||
| @@ -24,11 +24,14 @@ Doctave | |||||||
| DokuWiki | DokuWiki | ||||||
| dompurify | dompurify | ||||||
| elkjs | elkjs | ||||||
|  | fcose | ||||||
| fontawesome | fontawesome | ||||||
|  | Forgejo | ||||||
| Foswiki | Foswiki | ||||||
| Gitea | Gitea | ||||||
| graphlib | graphlib | ||||||
| Grav | Grav | ||||||
|  | icones | ||||||
| iconify | iconify | ||||||
| Inkdrop | Inkdrop | ||||||
| jiti | jiti | ||||||
|   | |||||||
| @@ -1,15 +1,18 @@ | |||||||
| Adamiecki | Adamiecki | ||||||
| arrowend | arrowend | ||||||
|  | Bendpoints | ||||||
| bmatrix | bmatrix | ||||||
| braintree | braintree | ||||||
| catmull | catmull | ||||||
| compositTitleSize | compositTitleSize | ||||||
|  | curv | ||||||
| doublecircle | doublecircle | ||||||
| elems | elems | ||||||
| gantt | gantt | ||||||
| gitgraph | gitgraph | ||||||
| gzipped | gzipped | ||||||
| handDrawn | handDrawn | ||||||
|  | kanban | ||||||
| knsv | knsv | ||||||
| Knut | Knut | ||||||
| marginx | marginx | ||||||
| @@ -23,6 +26,7 @@ multigraph | |||||||
| nodesep | nodesep | ||||||
| NOTEGROUP | NOTEGROUP | ||||||
| Pinterest | Pinterest | ||||||
|  | procs | ||||||
| rankdir | rankdir | ||||||
| ranksep | ranksep | ||||||
| rect | rect | ||||||
|   | |||||||
| @@ -4,3 +4,4 @@ handDrawn | |||||||
| KOEPF | KOEPF | ||||||
| neato | neato | ||||||
| newbranch | newbranch | ||||||
|  | validify | ||||||
|   | |||||||
| @@ -8,7 +8,10 @@ import { defaultOptions, getBuildConfig } from './util.js'; | |||||||
| const shouldVisualize = process.argv.includes('--visualize'); | const shouldVisualize = process.argv.includes('--visualize'); | ||||||
|  |  | ||||||
| const buildPackage = async (entryName: keyof typeof packageOptions) => { | 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[] = [ |   const buildConfigs: MermaidBuildOptions[] = [ | ||||||
|     // package.mjs |     // package.mjs | ||||||
|     { ...commonOptions }, |     { ...commonOptions }, | ||||||
| @@ -40,7 +43,7 @@ const buildPackage = async (entryName: keyof typeof packageOptions) => { | |||||||
|         continue; |         continue; | ||||||
|       } |       } | ||||||
|       const fileName = Object.keys(metafile.outputs) |       const fileName = Object.keys(metafile.outputs) | ||||||
|         .find((file) => !file.includes('chunks') && file.endsWith('js')) |         .find((file) => !file.includes('chunks') && file.endsWith('js'))! | ||||||
|         .replace('dist/', ''); |         .replace('dist/', ''); | ||||||
|       // Upload metafile into https://esbuild.github.io/analyze/ |       // Upload metafile into https://esbuild.github.io/analyze/ | ||||||
|       await writeFile(`stats/${fileName}.meta.json`, JSON.stringify(metafile)); |       await writeFile(`stats/${fileName}.meta.json`, JSON.stringify(metafile)); | ||||||
|   | |||||||
| @@ -9,13 +9,18 @@ import { generateLangium } from '../.build/generateLangium.js'; | |||||||
| import { defaultOptions, getBuildConfig } from './util.js'; | import { defaultOptions, getBuildConfig } from './util.js'; | ||||||
|  |  | ||||||
| const configs = Object.values(packageOptions).map(({ packageName }) => | const configs = Object.values(packageOptions).map(({ packageName }) => | ||||||
|   getBuildConfig({ ...defaultOptions, minify: false, core: false, entryName: packageName }) |   getBuildConfig({ | ||||||
|  |     ...defaultOptions, | ||||||
|  |     minify: false, | ||||||
|  |     core: false, | ||||||
|  |     options: packageOptions[packageName], | ||||||
|  |   }) | ||||||
| ); | ); | ||||||
| const mermaidIIFEConfig = getBuildConfig({ | const mermaidIIFEConfig = getBuildConfig({ | ||||||
|   ...defaultOptions, |   ...defaultOptions, | ||||||
|   minify: false, |   minify: false, | ||||||
|   core: false, |   core: false, | ||||||
|   entryName: 'mermaid', |   options: packageOptions.mermaid, | ||||||
|   format: 'iife', |   format: 'iife', | ||||||
| }); | }); | ||||||
| configs.push(mermaidIIFEConfig); | configs.push(mermaidIIFEConfig); | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ import { fileURLToPath } from 'url'; | |||||||
| import type { BuildOptions } from 'esbuild'; | import type { BuildOptions } from 'esbuild'; | ||||||
| import { readFileSync } from 'fs'; | import { readFileSync } from 'fs'; | ||||||
| import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | ||||||
| import { packageOptions } from '../.build/common.js'; | import type { PackageOptions } from '../.build/common.js'; | ||||||
| import { jisonPlugin } from './jisonPlugin.js'; | import { jisonPlugin } from './jisonPlugin.js'; | ||||||
|  |  | ||||||
| const __dirname = fileURLToPath(new URL('.', import.meta.url)); | const __dirname = fileURLToPath(new URL('.', import.meta.url)); | ||||||
| @@ -13,10 +13,10 @@ export interface MermaidBuildOptions extends BuildOptions { | |||||||
|   core: boolean; |   core: boolean; | ||||||
|   metafile: boolean; |   metafile: boolean; | ||||||
|   format: 'esm' | 'iife'; |   format: 'esm' | 'iife'; | ||||||
|   entryName: keyof typeof packageOptions; |   options: PackageOptions; | ||||||
| } | } | ||||||
|  |  | ||||||
| export const defaultOptions: Omit<MermaidBuildOptions, 'entryName'> = { | export const defaultOptions: Omit<MermaidBuildOptions, 'entryName' | 'options'> = { | ||||||
|   minify: false, |   minify: false, | ||||||
|   metafile: false, |   metafile: false, | ||||||
|   core: false, |   core: false, | ||||||
| @@ -52,9 +52,14 @@ const getFileName = (fileName: string, { core, format, minify }: MermaidBuildOpt | |||||||
| }; | }; | ||||||
|  |  | ||||||
| export const getBuildConfig = (options: MermaidBuildOptions): BuildOptions => { | 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 external: string[] = ['require', 'fs', 'path']; | ||||||
|   const { name, file, packageName } = packageOptions[entryName]; |  | ||||||
|   const outFileName = getFileName(name, options); |   const outFileName = getFileName(name, options); | ||||||
|   const output: BuildOptions = buildOptions({ |   const output: BuildOptions = buildOptions({ | ||||||
|     absWorkingDir: resolve(__dirname, `../packages/${packageName}`), |     absWorkingDir: resolve(__dirname, `../packages/${packageName}`), | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								.github/lychee.toml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/lychee.toml
									
									
									
									
										vendored
									
									
								
							| @@ -44,7 +44,13 @@ exclude = [ | |||||||
| "https://chromewebstore.google.com", | "https://chromewebstore.google.com", | ||||||
|  |  | ||||||
| # Drupal 403 | # Drupal 403 | ||||||
| "https://(www.)?drupal.org" | "https://(www.)?drupal.org", | ||||||
|  |  | ||||||
|  | # Swimm returns 404, eventhough the link is valid | ||||||
|  | "https://docs.swimm.io", | ||||||
|  |  | ||||||
|  | # Timeout | ||||||
|  | "https://huehive.co" | ||||||
| ] | ] | ||||||
|  |  | ||||||
| # Exclude all private IPs from checking. | # 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) | - [ ] :book: have read the [contribution guidelines](https://mermaid.js.org/community/contributing.html) | ||||||
| - [ ] :computer: have added necessary unit/e2e tests. | - [ ] :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. | - [ ] :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!** 🎉 |  | ||||||
							
								
								
									
										10
									
								
								.github/workflows/autofix.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/autofix.yml
									
									
									
									
										vendored
									
									
								
							| @@ -7,17 +7,19 @@ on: | |||||||
| permissions: | permissions: | ||||||
|   contents: read |   contents: read | ||||||
|  |  | ||||||
|  | concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   autofix: |   autofix: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
| @@ -40,4 +42,4 @@ jobs: | |||||||
|         working-directory: ./packages/mermaid |         working-directory: ./packages/mermaid | ||||||
|         run: pnpm run docs:build |         run: pnpm run docs:build | ||||||
|  |  | ||||||
|       - uses: autofix-ci/action@ff86a557419858bb967097bfc916833f5647fa8c |       - uses: autofix-ci/action@551dded8c6cc8a1054039c8bc0b8b48c51dfc6ef # main | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								.github/workflows/build-docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/build-docs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,6 +8,8 @@ on: | |||||||
|   pull_request: |   pull_request: | ||||||
|   merge_group: |   merge_group: | ||||||
|  |  | ||||||
|  | concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   contents: read |   contents: read | ||||||
|  |  | ||||||
| @@ -16,12 +18,12 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version-file: '.node-version' |           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@v4 |  | ||||||
|         # 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 |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout repository |       - 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 |       - name: Check for difference in README.md and docs/README.md | ||||||
|         run: | |         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 |       - synchronize | ||||||
|       - ready_for_review |       - ready_for_review | ||||||
|  |  | ||||||
|  | permissions: # added using https://github.com/step-security/secure-repo | ||||||
|  |   contents: read | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   analyze: |   analyze: | ||||||
|     name: Analyze |     name: Analyze | ||||||
| @@ -29,11 +32,11 @@ jobs: | |||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       # Initializes the CodeQL tools for scanning. |       # Initializes the CodeQL tools for scanning. | ||||||
|       - name: Initialize CodeQL |       - name: Initialize CodeQL | ||||||
|         uses: github/codeql-action/init@v3 |         uses: github/codeql-action/init@c36620d31ac7c881962c3d9dd939c40ec9434f2b # v3.26.12 | ||||||
|         with: |         with: | ||||||
|           config-file: ./.github/codeql/codeql-config.yml |           config-file: ./.github/codeql/codeql-config.yml | ||||||
|           languages: ${{ matrix.language }} |           languages: ${{ matrix.language }} | ||||||
| @@ -45,7 +48,7 @@ jobs: | |||||||
|       # Autobuild attempts to build any compiled languages  (C/C++, C#, or Java). |       # 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) |       # If this step fails, then you should remove it and run the build manually (see below) | ||||||
|       - name: Autobuild |       - name: Autobuild | ||||||
|         uses: github/codeql-action/autobuild@v3 |         uses: github/codeql-action/autobuild@c36620d31ac7c881962c3d9dd939c40ec9434f2b # v3.26.12 | ||||||
|  |  | ||||||
|       # ℹ️ Command-line programs to run using the OS shell. |       # ℹ️ 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 |       # 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun | ||||||
| @@ -59,4 +62,4 @@ jobs: | |||||||
|       #   make release |       #   make release | ||||||
|  |  | ||||||
|       - name: Perform CodeQL Analysis |       - name: Perform CodeQL Analysis | ||||||
|         uses: github/codeql-action/analyze@v3 |         uses: github/codeql-action/analyze@c36620d31ac7c881962c3d9dd939c40ec9434f2b # v3.26.12 | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/dependency-review.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/dependency-review.yml
									
									
									
									
										vendored
									
									
								
							| @@ -15,6 +15,6 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: 'Checkout Repository' |       - name: 'Checkout Repository' | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|       - name: 'Dependency Review' |       - 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 |         default: master | ||||||
|         description: 'Parent branch to use for PRs' |         description: 'Parent branch to use for PRs' | ||||||
|  |  | ||||||
|  | concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   contents: read |   contents: read | ||||||
|  |  | ||||||
| @@ -30,13 +32,13 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           echo "::error,title=Not using Applitools::APPLITOOLS_API_KEY is empty, disabling Applitools for this 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@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
| @@ -52,7 +54,7 @@ jobs: | |||||||
|           APPLITOOLS_SERVER_URL: 'https://eyesapi.applitools.com' |           APPLITOOLS_SERVER_URL: 'https://eyesapi.applitools.com' | ||||||
|  |  | ||||||
|       - name: Cypress run |       - name: Cypress run | ||||||
|         uses: cypress-io/github-action@v4 |         uses: cypress-io/github-action@d79d2d530a66e641eb4a5f227e13bc985c60b964 # v4.2.2 | ||||||
|         id: cypress |         id: cypress | ||||||
|         with: |         with: | ||||||
|           start: pnpm run dev |           start: pnpm run dev | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								.github/workflows/e2e-timings.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								.github/workflows/e2e-timings.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | |||||||
|  | name: E2E - Generate Timings | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   # run this workflow every night at 3am | ||||||
|  |   schedule: | ||||||
|  |     - cron: '28 3 * * *' | ||||||
|  |   # or when the user triggers it from GitHub Actions page | ||||||
|  |   workflow_dispatch: | ||||||
|  |  | ||||||
|  | concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   contents: write | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   timings: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     container: | ||||||
|  |       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@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|  |       - name: Setup Node.js | ||||||
|  |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|  |         with: | ||||||
|  |           node-version-file: '.node-version' | ||||||
|  |       - name: Install dependencies | ||||||
|  |         uses: cypress-io/github-action@0da3c06ed8217b912deea9d8ee69630baed1737e # v6.7.6 | ||||||
|  |         with: | ||||||
|  |           runTests: false | ||||||
|  |       - name: Cypress run | ||||||
|  |         uses: cypress-io/github-action@0da3c06ed8217b912deea9d8ee69630baed1737e # v6.7.6 | ||||||
|  |         id: cypress | ||||||
|  |         with: | ||||||
|  |           install: false | ||||||
|  |           start: pnpm run dev:coverage | ||||||
|  |           wait-on: 'http://localhost:9000' | ||||||
|  |           browser: chrome | ||||||
|  |           publish-summary: false | ||||||
|  |         env: | ||||||
|  |           VITEST_COVERAGE: true | ||||||
|  |           CYPRESS_COMMIT: ${{ github.sha }} | ||||||
|  |           SPLIT: 1 | ||||||
|  |           SPLIT_INDEX: 0 | ||||||
|  |           SPLIT_FILE: 'cypress/timings.json' | ||||||
|  |       - name: Commit changes | ||||||
|  |         uses: EndBug/add-and-commit@a94899bca583c204427a224a7af87c02f9b325d5 # v9.1.4 | ||||||
|  |         with: | ||||||
|  |           add: 'cypress/timings.json' | ||||||
|  |           author_name: 'github-actions[bot]' | ||||||
|  |           author_email: '41898282+github-actions[bot]@users.noreply.github.com' | ||||||
|  |           message: 'chore: update E2E timings' | ||||||
							
								
								
									
										64
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										64
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							| @@ -2,11 +2,15 @@ name: E2E | |||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches-ignore: |     branches: | ||||||
|       - 'gh-readonly-queue/**' |       - develop | ||||||
|  |       - master | ||||||
|  |       - release/** | ||||||
|   pull_request: |   pull_request: | ||||||
|   merge_group: |   merge_group: | ||||||
|  |  | ||||||
|  | concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   contents: read |   contents: read | ||||||
|  |  | ||||||
| @@ -24,7 +28,8 @@ env: | |||||||
|       ) ||  |       ) ||  | ||||||
|       github.event.before |       github.event.before | ||||||
|     }} |     }} | ||||||
|   shouldRunParallel: ${{ secrets.CYPRESS_RECORD_KEY != '' && !(github.event_name == 'push' && github.ref == 'refs/heads/develop') }} |   RUN_VISUAL_TEST: >- | ||||||
|  |     ${{ github.repository == 'mermaid-js/mermaid' && (github.event_name != 'pull_request' || !startsWith(github.head_ref, 'renovate/')) }} | ||||||
| jobs: | jobs: | ||||||
|   cache: |   cache: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
| @@ -32,15 +37,15 @@ jobs: | |||||||
|       image: cypress/browsers:node-20.11.0-chrome-121.0.6167.85-1-ff-120.0-edge-121.0.2277.83-1 |       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 |       options: --user 1001 | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
|       - name: Cache snapshots |       - name: Cache snapshots | ||||||
|         id: cache-snapshot |         id: cache-snapshot | ||||||
|         uses: actions/cache@v4 |         uses: actions/cache@0c45773b623bea8c8e75f6c82b208c3cf94ea4f9 # v4.0.2 | ||||||
|         with: |         with: | ||||||
|           save-always: true |           save-always: true | ||||||
|           path: ./cypress/snapshots |           path: ./cypress/snapshots | ||||||
| @@ -49,13 +54,13 @@ jobs: | |||||||
|       # If a snapshot for a given Hash is not found, we checkout that commit, run the tests and cache the snapshots. |       # 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 |       - name: Switch to base branch | ||||||
|         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} |         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|         with: |         with: | ||||||
|           ref: ${{ env.targetHash }} |           ref: ${{ env.targetHash }} | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} |         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} | ||||||
|         uses: cypress-io/github-action@v6 |         uses: cypress-io/github-action@0da3c06ed8217b912deea9d8ee69630baed1737e # v6.7.6 | ||||||
|         with: |         with: | ||||||
|           # just perform install |           # just perform install | ||||||
|           runTests: false |           runTests: false | ||||||
| @@ -76,28 +81,28 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         containers: [1, 2, 3, 4] |         containers: [1, 2, 3, 4, 5] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       # These cached snapshots are downloaded, providing the reference snapshots. |       # These cached snapshots are downloaded, providing the reference snapshots. | ||||||
|       - name: Cache snapshots |       - name: Cache snapshots | ||||||
|         id: cache-snapshot |         id: cache-snapshot | ||||||
|         uses: actions/cache/restore@v4 |         uses: actions/cache/restore@0c45773b623bea8c8e75f6c82b208c3cf94ea4f9 # v4.0.2 | ||||||
|         with: |         with: | ||||||
|           path: ./cypress/snapshots |           path: ./cypress/snapshots | ||||||
|           key: ${{ runner.os }}-snapshots-${{ env.targetHash }} |           key: ${{ runner.os }}-snapshots-${{ env.targetHash }} | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         uses: cypress-io/github-action@v6 |         uses: cypress-io/github-action@0da3c06ed8217b912deea9d8ee69630baed1737e # v6.7.6 | ||||||
|         with: |         with: | ||||||
|           runTests: false |           runTests: false | ||||||
|  |  | ||||||
| @@ -113,11 +118,8 @@ jobs: | |||||||
|       # Install NPM dependencies, cache them correctly |       # Install NPM dependencies, cache them correctly | ||||||
|       # and run all Cypress tests |       # and run all Cypress tests | ||||||
|       - name: Cypress run |       - name: Cypress run | ||||||
|         uses: cypress-io/github-action@v6 |         uses: cypress-io/github-action@0da3c06ed8217b912deea9d8ee69630baed1737e # v6.7.6 | ||||||
|         id: cypress |         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.shouldRunParallel == 'true' || ( matrix.containers == 1 ) }} |  | ||||||
|         with: |         with: | ||||||
|           install: false |           install: false | ||||||
|           start: pnpm run dev:coverage |           start: pnpm run dev:coverage | ||||||
| @@ -125,19 +127,25 @@ jobs: | |||||||
|           browser: chrome |           browser: chrome | ||||||
|           # Disable recording if we don't have an API key |           # Disable recording if we don't have an API key | ||||||
|           # e.g. if this action was run from a fork |           # e.g. if this action was run from a fork | ||||||
|           record: ${{ env.shouldRunParallel == 'true' }} |           record: ${{ env.RUN_VISUAL_TEST == 'true' && secrets.CYPRESS_RECORD_KEY != '' }} | ||||||
|           parallel: ${{ env.shouldRunParallel == 'true' }} |  | ||||||
|         env: |         env: | ||||||
|           CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} |           # Only set Argos environment variables if the visual test comment trigger is present | ||||||
|           VITEST_COVERAGE: true |           ARGOS_TOKEN: ${{ env.RUN_VISUAL_TEST == 'true' && secrets.ARGOS_TOKEN || '' }} | ||||||
|  |           ARGOS_PARALLEL: ${{ env.RUN_VISUAL_TEST == 'true' }} | ||||||
|  |           ARGOS_PARALLEL_TOTAL: ${{ env.RUN_VISUAL_TEST == 'true' && strategy.job-total || 1 }} | ||||||
|  |           ARGOS_PARALLEL_INDEX: ${{ env.RUN_VISUAL_TEST == 'true' && matrix.containers || 1 }} | ||||||
|  |           GITHUB_REPOSITORY: ${{ github.repository }} | ||||||
|  |           GITHUB_JOB: ${{ github.job }} | ||||||
|  |           GITHUB_RUN_ID: ${{ github.run_id }} | ||||||
|           CYPRESS_COMMIT: ${{ github.sha }} |           CYPRESS_COMMIT: ${{ github.sha }} | ||||||
|           ARGOS_TOKEN: ${{ secrets.ARGOS_TOKEN }} |           CYPRESS_RECORD_KEY: ${{ env.RUN_VISUAL_TEST == 'true' && secrets.CYPRESS_RECORD_KEY || ''}} | ||||||
|           ARGOS_PARALLEL: ${{ env.shouldRunParallel == 'true' }} |           SPLIT: ${{ strategy.job-total }} | ||||||
|           ARGOS_PARALLEL_TOTAL: 4 |           SPLIT_INDEX: ${{ strategy.job-index }} | ||||||
|           ARGOS_PARALLEL_INDEX: ${{ matrix.containers }} |           SPLIT_FILE: 'cypress/timings.json' | ||||||
|  |           VITEST_COVERAGE: true | ||||||
|  |  | ||||||
|       - name: Upload Coverage to Codecov |       - 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 |         # Run step only pushes to develop and pull_requests | ||||||
|         if: ${{ steps.cypress.conclusion == 'success' && (github.event_name == 'pull_request' || github.ref == 'refs/heads/develop')}} |         if: ${{ steps.cypress.conclusion == 'success' && (github.event_name == 'pull_request' || github.ref == 'refs/heads/develop')}} | ||||||
|         with: |         with: | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								.github/workflows/issue-triage.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/issue-triage.yml
									
									
									
									
										vendored
									
									
								
							| @@ -4,11 +4,17 @@ on: | |||||||
|   issues: |   issues: | ||||||
|     types: [opened] |     types: [opened] | ||||||
|  |  | ||||||
|  | permissions: # added using https://github.com/step-security/secure-repo | ||||||
|  |   contents: read | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   triage: |   triage: | ||||||
|  |     permissions: | ||||||
|  |       issues: write # for andymckay/labeler to label issues | ||||||
|  |       pull-requests: write # for andymckay/labeler to label PRs | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: andymckay/labeler@1.0.4 |       - uses: andymckay/labeler@e6c4322d0397f3240f0e7e30a33b5c5df2d39e90 # 1.0.4 | ||||||
|         with: |         with: | ||||||
|           repo-token: '${{ secrets.GITHUB_TOKEN }}' |           repo-token: '${{ secrets.GITHUB_TOKEN }}' | ||||||
|           add-labels: 'Status: Triage' |           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 |     # * is a special character in YAML so you have to quote this string | ||||||
|     - cron: '30 8 * * *' |     - cron: '30 8 * * *' | ||||||
|  |  | ||||||
|  | permissions: # added using https://github.com/step-security/secure-repo | ||||||
|  |   contents: read | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   link-checker: |   link-checker: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
| @@ -26,17 +29,17 @@ jobs: | |||||||
|       # lychee only uses the GITHUB_TOKEN to avoid rate-limiting |       # lychee only uses the GITHUB_TOKEN to avoid rate-limiting | ||||||
|       contents: read |       contents: read | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       - name: Restore lychee cache |       - name: Restore lychee cache | ||||||
|         uses: actions/cache@v4 |         uses: actions/cache@0c45773b623bea8c8e75f6c82b208c3cf94ea4f9 # v4.0.2 | ||||||
|         with: |         with: | ||||||
|           path: .lycheecache |           path: .lycheecache | ||||||
|           key: cache-lychee-${{ github.sha }} |           key: cache-lychee-${{ github.sha }} | ||||||
|           restore-keys: cache-lychee- |           restore-keys: cache-lychee- | ||||||
|  |  | ||||||
|       - name: Link Checker |       - name: Link Checker | ||||||
|         uses: lycheeverse/lychee-action@v1.9.3 |         uses: lycheeverse/lychee-action@c053181aa0c3d17606addfe97a9075a32723548a # v1.9.3 | ||||||
|         with: |         with: | ||||||
|           args: >- |           args: >- | ||||||
|             --config .github/lychee.toml |             --config .github/lychee.toml | ||||||
|   | |||||||
							
								
								
									
										27
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										27
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							| @@ -4,26 +4,32 @@ on: | |||||||
|   push: |   push: | ||||||
|   merge_group: |   merge_group: | ||||||
|   pull_request: |   pull_request: | ||||||
|     types: |  | ||||||
|       - opened |  | ||||||
|       - synchronize |  | ||||||
|       - ready_for_review |  | ||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
|  |  | ||||||
|  | concurrency: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |  | ||||||
| permissions: | permissions: | ||||||
|   contents: write |   contents: write | ||||||
|  |  | ||||||
| jobs: | 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: |   lint: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
| @@ -82,3 +88,10 @@ jobs: | |||||||
|         working-directory: ./packages/mermaid |         working-directory: ./packages/mermaid | ||||||
|         continue-on-error: ${{ github.event_name == 'push' }} |         continue-on-error: ${{ github.event_name == 'push' }} | ||||||
|         run: pnpm run docs:verify |         run: pnpm run docs:verify | ||||||
|  |  | ||||||
|  |       - uses: testomatio/check-tests@0ea638fcec1820cf2e7b9854fdbdd04128a55bd4 # stable | ||||||
|  |         with: | ||||||
|  |           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 |       pull-requests: write # write permission is required to label PRs | ||||||
|     steps: |     steps: | ||||||
|       - name: Label PR |       - name: Label PR | ||||||
|         uses: release-drafter/release-drafter@v6 |         uses: release-drafter/release-drafter@3f0f87098bd6b5c5b9a36d49c41d998ea58f9348 # v6.0.0 | ||||||
|         with: |         with: | ||||||
|           config-name: pr-labeler.yml |           config-name: pr-labeler.yml | ||||||
|           disable-autolabeler: false |           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 |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
| @@ -37,13 +37,13 @@ jobs: | |||||||
|         run: pnpm install --frozen-lockfile |         run: pnpm install --frozen-lockfile | ||||||
|  |  | ||||||
|       - name: Setup Pages |       - name: Setup Pages | ||||||
|         uses: actions/configure-pages@v4 |         uses: actions/configure-pages@1f0c5cde4bc74cd7e1254d0cb4de8d49e9068c7d # v4.0.0 | ||||||
|  |  | ||||||
|       - name: Run Build |       - name: Run Build | ||||||
|         run: pnpm --filter mermaid run docs:build:vitepress |         run: pnpm --filter mermaid run docs:build:vitepress | ||||||
|  |  | ||||||
|       - name: Upload artifact |       - name: Upload artifact | ||||||
|         uses: actions/upload-pages-artifact@v3 |         uses: actions/upload-pages-artifact@56afc609e74202658d3ffba0e8f6dda462b719fa # v3.0.1 | ||||||
|         with: |         with: | ||||||
|           path: packages/mermaid/src/vitepress/.vitepress/dist |           path: packages/mermaid/src/vitepress/.vitepress/dist | ||||||
|  |  | ||||||
| @@ -56,4 +56,4 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       - name: Deploy to GitHub Pages |       - name: Deploy to GitHub Pages | ||||||
|         id: deployment |         id: deployment | ||||||
|         uses: actions/deploy-pages@v4 |         uses: actions/deploy-pages@d6db90164ac5ed86f2b6aed7e0febac5b3c0c03e # v4.0.5 | ||||||
|   | |||||||
							
								
								
									
										24
									
								
								.github/workflows/release-draft.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/release-draft.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,24 +0,0 @@ | |||||||
| name: Draft Release |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - master |  | ||||||
|       - release/** |  | ||||||
|  |  | ||||||
| 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: |   publish-preview: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|         with: |         with: | ||||||
|           fetch-depth: 0 |           fetch-depth: 0 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
| @@ -28,7 +28,7 @@ jobs: | |||||||
|           CYPRESS_CACHE_FOLDER: .cache/Cypress |           CYPRESS_CACHE_FOLDER: .cache/Cypress | ||||||
|  |  | ||||||
|       - name: Install Json |       - name: Install Json | ||||||
|         run: npm i json --global |         run: npm i json@11.0.0 --global | ||||||
|  |  | ||||||
|       - name: Publish |       - name: Publish | ||||||
|         working-directory: ./packages/mermaid |         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@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|  |         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@v4 |  | ||||||
|         # 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@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|  |         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@3de3850952bec538fde60aac71731376e57b9b57 # v1.4.8 | ||||||
|  |         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@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |         with: | ||||||
|  |           persist-credentials: false | ||||||
|  |       - name: Run analysis | ||||||
|  |         uses: ossf/scorecard-action@dc50aa9510b46c811795eb24b2f1ba02a914e534 # v2.3.3 | ||||||
|  |         with: | ||||||
|  |           results_file: results.sarif | ||||||
|  |           results_format: sarif | ||||||
|  |           publish_results: true | ||||||
|  |       - name: Upload artifact | ||||||
|  |         uses: actions/upload-artifact@65c4c4a1ddee5b72f698fdd19549f0f0fb45cf08 # v4.6.0 | ||||||
|  |         with: | ||||||
|  |           name: SARIF file | ||||||
|  |           path: results.sarif | ||||||
|  |           retention-days: 5 | ||||||
|  |       - name: Upload to code-scanning | ||||||
|  |         uses: github/codeql-action/upload-sarif@c36620d31ac7c881962c3d9dd939c40ec9434f2b # v3.26.12 | ||||||
|  |         with: | ||||||
|  |           sarif_file: results.sarif | ||||||
							
								
								
									
										12
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,13 +9,13 @@ jobs: | |||||||
|   unit-test: |   unit-test: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@0a44ba7841725637a19e28fa30b79a866c81b0a6 # v4.0.4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version-file: '.node-version' |           node-version-file: '.node-version' | ||||||
| @@ -38,8 +38,12 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           pnpm exec vitest run ./packages/mermaid/src/diagrams/gantt/ganttDb.spec.ts --coverage |           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 |       - 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 |         # Run step only pushes to develop and pull_requests | ||||||
|         if: ${{ github.event_name == 'pull_request' || github.ref == 'refs/heads/develop' }} |         if: ${{ github.event_name == 'pull_request' || github.ref == 'refs/heads/develop' }} | ||||||
|         with: |         with: | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/unlock-reopened-issues.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/unlock-reopened-issues.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,6 +8,6 @@ jobs: | |||||||
|   triage: |   triage: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: Dunning-Kruger/unlock-issues@v1 |       - uses: Dunning-Kruger/unlock-issues@b06b7f7e5c3f2eaa1c6d5d89f40930e4d6d9699e # v1 | ||||||
|         with: |         with: | ||||||
|           repo-token: '${{ secrets.GITHUB_TOKEN }}' |           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: |   update-browser-list: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||||||
|       - uses: pnpm/action-setup@v4 |       - uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||||||
|       - run: npx update-browserslist-db@latest |       - run: npx update-browserslist-db@latest | ||||||
|       - name: Commit changes |       - name: Commit changes | ||||||
|         uses: EndBug/add-and-commit@v9 |         uses: EndBug/add-and-commit@a94899bca583c204427a224a7af87c02f9b325d5 # v9.1.4 | ||||||
|         with: |         with: | ||||||
|           author_name: ${{ github.actor }} |           author_name: ${{ github.actor }} | ||||||
|           author_email: ${{ github.actor }}@users.noreply.github.com |           author_email: ${{ github.actor }}@users.noreply.github.com | ||||||
|           message: 'chore: update browsers list' |           message: 'chore: update browsers list' | ||||||
|           push: false |           push: false | ||||||
|       - name: Create Pull Request |       - name: Create Pull Request | ||||||
|         uses: peter-evans/create-pull-request@v6 |         uses: peter-evans/create-pull-request@c5a7806660adbe173f04e3e038b0ccdcd758773c # v6.1.0 | ||||||
|         with: |         with: | ||||||
|           branch: update-browserslist |           branch: update-browserslist | ||||||
|           title: 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 | #!/usr/bin/env sh | ||||||
| . "$(dirname "$0")/_/husky.sh" |  | ||||||
|  |  | ||||||
| NODE_OPTIONS="--max_old_space_size=8192" pnpm run pre-commit | NODE_OPTIONS="--max_old_space_size=8192" pnpm run pre-commit | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -1,2 +1,13 @@ | |||||||
| FROM node:20.12.2-alpine3.19 AS base | FROM node:20.12.2-alpine3.19@sha256:7a91aa397f2e2dfbfcdad2e2d72599f374e0b0172be1d86eeb73f1d33f36a4b2 | ||||||
| RUN wget -qO- https://get.pnpm.io/install.sh | ENV="$HOME/.shrc" SHELL="$(which sh)" sh - |  | ||||||
|  | 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 | ||||||
|   | |||||||
							
								
								
									
										41
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								README.md
									
									
									
									
									
								
							| @@ -35,7 +35,8 @@ Try Live Editor previews of future releases: <a href="https://develop.git.mermai | |||||||
| [](https://www.npmjs.com/package/mermaid) | [](https://www.npmjs.com/package/mermaid) | ||||||
| [](https://discord.gg/AgrbSrBer3) | [](https://discord.gg/AgrbSrBer3) | ||||||
| [](https://twitter.com/mermaidjs_) | [](https://twitter.com/mermaidjs_) | ||||||
| [](https://argos-ci.com) | [](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="" /> | <img src="./img/header.png" alt="" /> | ||||||
|  |  | ||||||
| @@ -82,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). | 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. | 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/"> | <a href="https://applitools.com/"> | ||||||
| @@ -90,6 +95,10 @@ In our release process we rely heavily on visual regression tests using [applito | |||||||
|  |  | ||||||
| <!-- </Main description> --> | <!-- </Main description> --> | ||||||
|  |  | ||||||
|  | ## Mermaid AI Bot | ||||||
|  |  | ||||||
|  | [Mermaid](https://codeparrot.ai/oracle?owner=mermaid-js&repo=mermaid) Bot will help you understand this repository better. You can ask for code examples, installation guide, debugging help and much more. | ||||||
|  |  | ||||||
| ## Examples | ## Examples | ||||||
|  |  | ||||||
| **The following are some examples of the diagrams, charts and graphs that can be made using Mermaid. Click here to jump into the [text syntax](https://mermaid.js.org/intro/syntax-reference.html).** | **The following are some examples of the diagrams, charts and graphs that can be made using Mermaid. Click here to jump into the [text syntax](https://mermaid.js.org/intro/syntax-reference.html).** | ||||||
| @@ -248,6 +257,34 @@ pie | |||||||
|  |  | ||||||
| ### Git graph [experimental - <a href="https://mermaid.live/edit#pako:eNqNkMFugzAMhl8F-VyVAR1tOW_aA-zKxSSGRCMJCk6lCvHuNZPKZdM0n-zf3_8r8QIqaIIGMqnB8kfEybQ--y4VnLP8-9RF9Mpkmm40hmlnDKmvkPiH_kfS7nFo_VN0FAf6XwocQGgxa_nGsm1bYEOOWmik1dRjGrmF1q-Cpkkj07u2HCI0PY4zHQATh8-7V9BwTPSE3iwOEd1OjQE1iWkBvk_bzQY7s0Sq4Hs7bHqKo8iGeZqbPN_WR7mpSd1RHpvPVhuMbG7XOq_L-oJlRfW5wteq0qorrpe-PBW9Pr8UJcK6rg-BLYPQ">live editor</a>] | ### Git graph [experimental - <a href="https://mermaid.live/edit#pako:eNqNkMFugzAMhl8F-VyVAR1tOW_aA-zKxSSGRCMJCk6lCvHuNZPKZdM0n-zf3_8r8QIqaIIGMqnB8kfEybQ--y4VnLP8-9RF9Mpkmm40hmlnDKmvkPiH_kfS7nFo_VN0FAf6XwocQGgxa_nGsm1bYEOOWmik1dRjGrmF1q-Cpkkj07u2HCI0PY4zHQATh8-7V9BwTPSE3iwOEd1OjQE1iWkBvk_bzQY7s0Sq4Hs7bHqKo8iGeZqbPN_WR7mpSd1RHpvPVhuMbG7XOq_L-oJlRfW5wteq0qorrpe-PBW9Pr8UJcK6rg-BLYPQ">live editor</a>] | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | gitGraph | ||||||
|  |   commit | ||||||
|  |   commit | ||||||
|  |   branch develop | ||||||
|  |   checkout develop | ||||||
|  |   commit | ||||||
|  |   commit | ||||||
|  |   checkout main | ||||||
|  |   merge develop | ||||||
|  |   commit | ||||||
|  |   commit | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ```mermaid | ||||||
|  | gitGraph | ||||||
|  |   commit | ||||||
|  |   commit | ||||||
|  |   branch develop | ||||||
|  |   checkout develop | ||||||
|  |   commit | ||||||
|  |   commit | ||||||
|  |   checkout main | ||||||
|  |   merge develop | ||||||
|  |   commit | ||||||
|  |   commit | ||||||
|  | ``` | ||||||
|  |  | ||||||
| ### Bar chart (using gantt chart) [<a href="https://mermaid.js.org/syntax/gantt.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNptkU1vhCAQhv8KIenNugiI4rkf6bmXpvEyFVxJFDYyNt1u9r8X63Z7WQ9m5pknLzieaBeMpQ3dg0dsPUkPOhwteXZIXmJcbCT3xMAxkuh8Z8kIEclyMIB209fqKcwTICFvG4IvFy_oLrZ-g9F26ILfQgvNFN94VaRXQ1iWqpumZBcu1J8p1E1TXDx59eQNr5LyEqjJn6hv5QnGNlxevZJmdLLpy5xJSzut45biYCfb0iaVxvawjNjS1p-TCguG16PvaIPzYjO67e3BwX6GiTY9jPFKH43DMF_hGMDY1J4oHg-_f8hFTJFd8L3br3yZx4QHxENsdrt1nO8dDstH3oVpF50ZYMbhU6ud4qoGLqyqBJRCmO6j0HXPZdGbihUc6Pmc0QP49xD-b5X69ZQv2gjO81IwzWqhC1lKrjJ6pA3nVS7SMiVjrKirWlYp5fs3osgrWeo00lorLWvOzz8JVbXm">live editor</a>] | ### Bar chart (using gantt chart) [<a href="https://mermaid.js.org/syntax/gantt.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNptkU1vhCAQhv8KIenNugiI4rkf6bmXpvEyFVxJFDYyNt1u9r8X63Z7WQ9m5pknLzieaBeMpQ3dg0dsPUkPOhwteXZIXmJcbCT3xMAxkuh8Z8kIEclyMIB209fqKcwTICFvG4IvFy_oLrZ-g9F26ILfQgvNFN94VaRXQ1iWqpumZBcu1J8p1E1TXDx59eQNr5LyEqjJn6hv5QnGNlxevZJmdLLpy5xJSzut45biYCfb0iaVxvawjNjS1p-TCguG16PvaIPzYjO67e3BwX6GiTY9jPFKH43DMF_hGMDY1J4oHg-_f8hFTJFd8L3br3yZx4QHxENsdrt1nO8dDstH3oVpF50ZYMbhU6ud4qoGLqyqBJRCmO6j0HXPZdGbihUc6Pmc0QP49xD-b5X69ZQv2gjO81IwzWqhC1lKrjJ6pA3nVS7SMiVjrKirWlYp5fs3osgrWeo00lorLWvOzz8JVbXm">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| @@ -430,7 +467,7 @@ A quick note from Knut Sveidqvist: | |||||||
| > | > | ||||||
| > _Thank you to [Tyler Long](https://github.com/tylerlong) who has been a collaborator since April 2017._ | > _Thank you to [Tyler Long](https://github.com/tylerlong) who has been a collaborator since April 2017._ | ||||||
| > | > | ||||||
| > _Thank you to the ever-growing list of [contributors](https://github.com/knsv/mermaid/graphs/contributors) that brought the project this far!_ | > _Thank you to the ever-growing list of [contributors](https://github.com/mermaid-js/mermaid/graphs/contributors) that brought the project this far!_ | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -358,7 +358,7 @@ _很不幸的是,鱼与熊掌不可兼得,在这个场景下它意味着在 | |||||||
|  |  | ||||||
| > _特别感谢 [d3](https://d3js.org/) 和 [dagre-d3](https://github.com/cpettitt/dagre-d3) 这两个优秀的项目,它们提供了图形布局和绘图工具库!_ > _同样感谢 [js-sequence-diagram](https://bramp.github.io/js-sequence-diagrams) 提供了时序图语法的使用。 感谢 Jessica Peter 提供了甘特图渲染的灵感。_ > _感谢 [Tyler Long](https://github.com/tylerlong) 从 2017 年四月开始成为了项目的合作者。_ | > _特别感谢 [d3](https://d3js.org/) 和 [dagre-d3](https://github.com/cpettitt/dagre-d3) 这两个优秀的项目,它们提供了图形布局和绘图工具库!_ > _同样感谢 [js-sequence-diagram](https://bramp.github.io/js-sequence-diagrams) 提供了时序图语法的使用。 感谢 Jessica Peter 提供了甘特图渲染的灵感。_ > _感谢 [Tyler Long](https://github.com/tylerlong) 从 2017 年四月开始成为了项目的合作者。_ | ||||||
| > | > | ||||||
| > _感谢越来越多的 [贡献者们](https://github.com/knsv/mermaid/graphs/contributors),没有你们,就没有这个项目的今天!_ | > _感谢越来越多的 [贡献者们](https://github.com/mermaid-js/mermaid/graphs/contributors),没有你们,就没有这个项目的今天!_ | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,8 +1,17 @@ | |||||||
| 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 eyesPlugin from '@applitools/eyes-cypress'; | ||||||
| import { registerArgosTask } from '@argos-ci/cypress/task'; | import { registerArgosTask } from '@argos-ci/cypress/task'; | ||||||
|  | import coverage from '@cypress/code-coverage/task'; | ||||||
|  | import { defineConfig } from 'cypress'; | ||||||
|  | import { addMatchImageSnapshotPlugin } from 'cypress-image-snapshot/plugin'; | ||||||
|  | import cypressSplit from 'cypress-split'; | ||||||
|  |  | ||||||
|  | const encodeArgosToken = (options: { | ||||||
|  |   owner: string; | ||||||
|  |   repository: string; | ||||||
|  |   jobId: string; | ||||||
|  |   runId: string; | ||||||
|  | }) => `tokenless-github-${Buffer.from(JSON.stringify(options), 'utf8').toString('base64')}`; | ||||||
|  | // cspell:ignore tokenless | ||||||
|  |  | ||||||
| export default eyesPlugin( | export default eyesPlugin( | ||||||
|   defineConfig({ |   defineConfig({ | ||||||
| @@ -13,6 +22,7 @@ export default eyesPlugin( | |||||||
|       specPattern: 'cypress/integration/**/*.{js,ts}', |       specPattern: 'cypress/integration/**/*.{js,ts}', | ||||||
|       setupNodeEvents(on, config) { |       setupNodeEvents(on, config) { | ||||||
|         coverage(on, config); |         coverage(on, config); | ||||||
|  |         cypressSplit(on, config); | ||||||
|         on('before:browser:launch', (browser, launchOptions) => { |         on('before:browser:launch', (browser, launchOptions) => { | ||||||
|           if (browser.name === 'chrome' && browser.isHeadless) { |           if (browser.name === 'chrome' && browser.isHeadless) { | ||||||
|             launchOptions.args.push('--window-size=1440,1024', '--force-device-scale-factor=1'); |             launchOptions.args.push('--window-size=1440,1024', '--force-device-scale-factor=1'); | ||||||
| @@ -21,11 +31,25 @@ export default eyesPlugin( | |||||||
|         }); |         }); | ||||||
|         // copy any needed variables from process.env to config.env |         // copy any needed variables from process.env to config.env | ||||||
|         config.env.useAppli = process.env.USE_APPLI ? true : false; |         config.env.useAppli = process.env.USE_APPLI ? true : false; | ||||||
|         config.env.useArgos = !!process.env.CI; |         config.env.useArgos = !!process.env.CI && !!process.env.ARGOS_TOKEN; | ||||||
|  |  | ||||||
|         if (config.env.useArgos) { |         if (config.env.useArgos) { | ||||||
|  |           if (!process.env.GITHUB_REPOSITORY) { | ||||||
|  |             throw new Error('GITHUB_REPOSITORY is not set'); | ||||||
|  |           } | ||||||
|  |           if (!process.env.GITHUB_JOB) { | ||||||
|  |             throw new Error('GITHUB_JOB is not set'); | ||||||
|  |           } | ||||||
|  |           if (!process.env.GITHUB_RUN_ID) { | ||||||
|  |             throw new Error('GITHUB_RUN_ID is not set'); | ||||||
|  |           } | ||||||
|           registerArgosTask(on, config, { |           registerArgosTask(on, config, { | ||||||
|             token: 'fc3a35cf5200db928d65b2047861582d9444032b', |             token: encodeArgosToken({ | ||||||
|  |               owner: process.env.GITHUB_REPOSITORY.split('/')[0], | ||||||
|  |               repository: process.env.GITHUB_REPOSITORY.split('/')[1], | ||||||
|  |               jobId: process.env.GITHUB_JOB, | ||||||
|  |               runId: process.env.GITHUB_RUN_ID, | ||||||
|  |             }), | ||||||
|           }); |           }); | ||||||
|         } else { |         } else { | ||||||
|           addMatchImageSnapshotPlugin(on, config); |           addMatchImageSnapshotPlugin(on, config); | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ export const mermaidUrl = ( | |||||||
|   options: CypressMermaidConfig, |   options: CypressMermaidConfig, | ||||||
|   api: boolean |   api: boolean | ||||||
| ): string => { | ): string => { | ||||||
|  |   options.handDrawnSeed = 1; | ||||||
|   const codeObject: CodeObject = { |   const codeObject: CodeObject = { | ||||||
|     code: graphStr, |     code: graphStr, | ||||||
|     mermaid: options, |     mermaid: options, | ||||||
| @@ -73,7 +74,7 @@ export const imgSnapshotTest = ( | |||||||
|  |  | ||||||
| export const urlSnapshotTest = ( | export const urlSnapshotTest = ( | ||||||
|   url: string, |   url: string, | ||||||
|   options: CypressMermaidConfig, |   options: CypressMermaidConfig = {}, | ||||||
|   _api = false, |   _api = false, | ||||||
|   validation?: any |   validation?: any | ||||||
| ): void => { | ): void => { | ||||||
| @@ -131,3 +132,10 @@ export const verifyScreenshot = (name: string): void => { | |||||||
|     cy.matchImageSnapshot(name); |     cy.matchImageSnapshot(name); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export const verifyNumber = (value: number, expected: number, deltaPercent = 10): void => { | ||||||
|  |   expect(value).to.be.within( | ||||||
|  |     expected * (1 - deltaPercent / 100), | ||||||
|  |     expected * (1 + deltaPercent / 100) | ||||||
|  |   ); | ||||||
|  | }; | ||||||
|   | |||||||
							
								
								
									
										233
									
								
								cypress/integration/rendering/architecture.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										233
									
								
								cypress/integration/rendering/architecture.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,233 @@ | |||||||
|  | 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} | ||||||
|  |             ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('should render an architecture diagram with a resonable height', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `architecture-beta | ||||||
|  |               group federated(cloud)[Federated Environment] | ||||||
|  |                   service server1(server)[System] in federated | ||||||
|  |                   service edge(server)[Edge Device] in federated | ||||||
|  |                   server1:R -- L:edge | ||||||
|  |  | ||||||
|  |               group on_prem(cloud)[Hub] | ||||||
|  |                   service firewall(server)[Firewall Device] in on_prem | ||||||
|  |                   service server(server)[Server] in on_prem | ||||||
|  |                   firewall:R -- L:server | ||||||
|  |  | ||||||
|  |                   service db1(database)[db1] in on_prem | ||||||
|  |                   service db2(database)[db2] in on_prem | ||||||
|  |                   service db3(database)[db3] in on_prem | ||||||
|  |                   service db4(database)[db4] in on_prem | ||||||
|  |                   service db5(database)[db5] in on_prem | ||||||
|  |                   service db6(database)[db6] in on_prem | ||||||
|  |  | ||||||
|  |                   junction mid in on_prem | ||||||
|  |                   server:B -- T:mid | ||||||
|  |  | ||||||
|  |                   junction 1Leftofmid in on_prem | ||||||
|  |                   1Leftofmid:R -- L:mid | ||||||
|  |                   1Leftofmid:B -- T:db1 | ||||||
|  |  | ||||||
|  |                   junction 2Leftofmid in on_prem | ||||||
|  |                   2Leftofmid:R -- L:1Leftofmid | ||||||
|  |                   2Leftofmid:B -- T:db2 | ||||||
|  |  | ||||||
|  |                   junction 3Leftofmid in on_prem | ||||||
|  |                   3Leftofmid:R -- L:2Leftofmid | ||||||
|  |                   3Leftofmid:B -- T:db3 | ||||||
|  |  | ||||||
|  |                   junction 1RightOfMid in on_prem | ||||||
|  |                   mid:R -- L:1RightOfMid | ||||||
|  |                   1RightOfMid:B -- T:db4 | ||||||
|  |                    | ||||||
|  |                   junction 2RightOfMid in on_prem | ||||||
|  |                   1RightOfMid:R -- L:2RightOfMid | ||||||
|  |                   2RightOfMid:B -- T:db5         | ||||||
|  |                    | ||||||
|  |                   junction 3RightOfMid in on_prem | ||||||
|  |                   2RightOfMid:R -- L:3RightOfMid | ||||||
|  |                   3RightOfMid:B -- T:db6          | ||||||
|  |  | ||||||
|  |                   edge:R -- L:firewall | ||||||
|  |       ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // Skipped as the layout is not deterministic, and causes issues in E2E tests. | ||||||
|  | describe.skip('architecture - external', () => { | ||||||
|  |   it('should allow adding external icons', () => { | ||||||
|  |     urlSnapshotTest('http://localhost:9000/architecture-external.html'); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
							
								
								
									
										1037
									
								
								cypress/integration/rendering/classDiagram-elk-v3.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1037
									
								
								cypress/integration/rendering/classDiagram-elk-v3.spec.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1041
									
								
								cypress/integration/rendering/classDiagram-handDrawn-v3.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1041
									
								
								cypress/integration/rendering/classDiagram-handDrawn-v3.spec.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -581,4 +581,63 @@ class C13["With Città foreign language"] | |||||||
|       { logLevel: 1, flowchart: { htmlLabels: false } } |       { 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); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										1031
									
								
								cypress/integration/rendering/classDiagram-v3.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1031
									
								
								cypress/integration/rendering/classDiagram-v3.spec.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -321,4 +321,37 @@ ORDER ||--|{ LINE-ITEM : contains | |||||||
|       { logLevel: 1 } |       { 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 } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| import { imgSnapshotTest, renderGraph } from '../../helpers/util.ts'; | import { imgSnapshotTest, renderGraph, verifyNumber } from '../../helpers/util.ts'; | ||||||
|  |  | ||||||
| describe.skip('Flowchart ELK', () => { | describe('Flowchart ELK', () => { | ||||||
|   it('1-elk: should render a simple flowchart', () => { |   it('1-elk: should render a simple flowchart', () => { | ||||||
|     imgSnapshotTest( |     imgSnapshotTest( | ||||||
|       `flowchart-elk TD |       `flowchart-elk TD | ||||||
| @@ -109,7 +109,7 @@ describe.skip('Flowchart ELK', () => { | |||||||
|       const style = svg.attr('style'); |       const style = svg.attr('style'); | ||||||
|       expect(style).to.match(/^max-width: [\d.]+px;$/); |       expect(style).to.match(/^max-width: [\d.]+px;$/); | ||||||
|       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join('')); |       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join('')); | ||||||
|       expect(maxWidthValue).to.be.within(230 * 0.95, 230 * 1.05); |       verifyNumber(maxWidthValue, 380); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|   it('8-elk: should render a flowchart when useMaxWidth is false', () => { |   it('8-elk: should render a flowchart when useMaxWidth is false', () => { | ||||||
| @@ -128,7 +128,7 @@ describe.skip('Flowchart ELK', () => { | |||||||
|       const width = parseFloat(svg.attr('width')); |       const width = parseFloat(svg.attr('width')); | ||||||
|       // use within because the absolute value can be slightly different depending on the environment ±5% |       // 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(height).to.be.within(446 * 0.95, 446 * 1.05); | ||||||
|       expect(width).to.be.within(230 * 0.95, 230 * 1.05); |       verifyNumber(width, 380); | ||||||
|       expect(svg).to.not.have.attr('style'); |       expect(svg).to.not.have.attr('style'); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
| @@ -692,7 +692,7 @@ A --> B | |||||||
|       {} |       {} | ||||||
|     ); |     ); | ||||||
|     cy.get('svg').should((svg) => { |     cy.get('svg').should((svg) => { | ||||||
|       const edges = svg.querySelectorAll('.edges > path'); |       const edges = svg[0].querySelectorAll('.edges > path'); | ||||||
|       edges.forEach((edge) => { |       edges.forEach((edge) => { | ||||||
|         expect(edge).to.have.class('flowchart-link'); |         expect(edge).to.have.class('flowchart-link'); | ||||||
|       }); |       }); | ||||||
| @@ -739,7 +739,7 @@ NL\`") --"\`1o **bold**\`"--> c | |||||||
|           { flowchart: { titleTopMargin: 0 } } |           { flowchart: { titleTopMargin: 0 } } | ||||||
|         ); |         ); | ||||||
|       }); |       }); | ||||||
|       it('Wrapping long text with a new line', () => { |       it.skip('Wrapping long text with a new line', () => { | ||||||
|         imgSnapshotTest( |         imgSnapshotTest( | ||||||
|           `%%{init: {"flowchart": {"htmlLabels": true}} }%% |           `%%{init: {"flowchart": {"htmlLabels": true}} }%% | ||||||
| flowchart-elk LR | flowchart-elk LR | ||||||
| @@ -841,7 +841,7 @@ end | |||||||
|           { flowchart: { titleTopMargin: 0 } } |           { flowchart: { titleTopMargin: 0 } } | ||||||
|         ); |         ); | ||||||
|       }); |       }); | ||||||
|       it('Sub graphs and markdown strings', () => { |       it('Sub graphs', () => { | ||||||
|         imgSnapshotTest( |         imgSnapshotTest( | ||||||
|           `--- |           `--- | ||||||
| config: | config: | ||||||
| @@ -857,6 +857,196 @@ flowchart LR | |||||||
|     D --> E |     D --> E | ||||||
|       A["A"] |       A["A"] | ||||||
|  |  | ||||||
|  | `, | ||||||
|  |           { flowchart: { titleTopMargin: 0 } } | ||||||
|  |         ); | ||||||
|  |       }); | ||||||
|  |       it('6080: should handle diamond shape intersections', () => { | ||||||
|  |         imgSnapshotTest( | ||||||
|  |           `--- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |  subgraph s1["Untitled subgraph"] | ||||||
|  |         n1["Evaluate"] | ||||||
|  |         n2["Option 1"] | ||||||
|  |         n3["Option 2"] | ||||||
|  |         n4["fa:fa-car Option 3"] | ||||||
|  |   end | ||||||
|  |  subgraph s2["Untitled subgraph"] | ||||||
|  |         n5["Evaluate"] | ||||||
|  |         n6["Option 1"] | ||||||
|  |         n7["Option 2"] | ||||||
|  |         n8["fa:fa-car Option 3"] | ||||||
|  |   end | ||||||
|  |     A["Start"] -- Some text --> B("Continue") | ||||||
|  |     B --> C{"Evaluate"} | ||||||
|  |     C -- One --> D["Option 1"] | ||||||
|  |     C -- Two --> E["Option 2"] | ||||||
|  |     C -- Three --> F["fa:fa-car Option 3"] | ||||||
|  |     n1 -- One --> n2 | ||||||
|  |     n1 -- Two --> n3 | ||||||
|  |     n1 -- Three --> n4 | ||||||
|  |     n5 -- One --> n6 | ||||||
|  |     n5 -- Two --> n7 | ||||||
|  |     n5 -- Three --> n8 | ||||||
|  |     n1@{ shape: diam} | ||||||
|  |     n2@{ shape: rect} | ||||||
|  |     n3@{ shape: rect} | ||||||
|  |     n4@{ shape: rect} | ||||||
|  |     n5@{ shape: diam} | ||||||
|  |     n6@{ shape: rect} | ||||||
|  |     n7@{ shape: rect} | ||||||
|  |     n8@{ shape: rect} | ||||||
|  |  | ||||||
|  | `, | ||||||
|  |           { flowchart: { titleTopMargin: 0 } } | ||||||
|  |         ); | ||||||
|  |       }); | ||||||
|  |  | ||||||
|  |       it('6088-1: should handle diamond shape intersections', () => { | ||||||
|  |         imgSnapshotTest( | ||||||
|  |           `--- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  |       flowchart LR | ||||||
|  |       subgraph S2 | ||||||
|  |       subgraph s1["APA"] | ||||||
|  |       D{"Use the editor"} | ||||||
|  |       end | ||||||
|  |  | ||||||
|  |  | ||||||
|  |       D -- Mermaid js --> I{"fa:fa-code Text"} | ||||||
|  |             D --> I | ||||||
|  |             D --> I | ||||||
|  |  | ||||||
|  |       end | ||||||
|  | `, | ||||||
|  |           { flowchart: { titleTopMargin: 0 } } | ||||||
|  |         ); | ||||||
|  |       }); | ||||||
|  |  | ||||||
|  |       it('6088-2: should handle diamond shape intersections', () => { | ||||||
|  |         imgSnapshotTest( | ||||||
|  |           `--- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  |       flowchart LR | ||||||
|  |       a | ||||||
|  |       subgraph s0["APA"] | ||||||
|  |       subgraph s8["APA"] | ||||||
|  |       subgraph s1["APA"] | ||||||
|  |         D{"X"} | ||||||
|  |         E[Q] | ||||||
|  |       end | ||||||
|  |       subgraph s3["BAPA"] | ||||||
|  |         F[Q] | ||||||
|  |         I | ||||||
|  |       end | ||||||
|  |             D --> I | ||||||
|  |             D --> I | ||||||
|  |             D --> I | ||||||
|  |  | ||||||
|  |       I{"X"} | ||||||
|  |       end | ||||||
|  |       end | ||||||
|  |  | ||||||
|  | `, | ||||||
|  |           { flowchart: { titleTopMargin: 0 } } | ||||||
|  |         ); | ||||||
|  |       }); | ||||||
|  |  | ||||||
|  |       it('6088-3: should handle diamond shape intersections', () => { | ||||||
|  |         imgSnapshotTest( | ||||||
|  |           `--- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  |       flowchart LR | ||||||
|  |       a | ||||||
|  |         D{"Use the editor"} | ||||||
|  |  | ||||||
|  |       D -- Mermaid js --> I{"fa:fa-code Text"} | ||||||
|  |       D-->I | ||||||
|  |       D-->I | ||||||
|  |  | ||||||
|  | `, | ||||||
|  |           { flowchart: { titleTopMargin: 0 } } | ||||||
|  |         ); | ||||||
|  |       }); | ||||||
|  |  | ||||||
|  |       it('6088-4: should handle diamond shape intersections', () => { | ||||||
|  |         imgSnapshotTest( | ||||||
|  |           `--- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |  subgraph s1["Untitled subgraph"] | ||||||
|  |         n1["Evaluate"] | ||||||
|  |         n2["Option 1"] | ||||||
|  |         n3["Option 2"] | ||||||
|  |         n4["fa:fa-car Option 3"] | ||||||
|  |   end | ||||||
|  |  subgraph s2["Untitled subgraph"] | ||||||
|  |         n5["Evaluate"] | ||||||
|  |         n6["Option 1"] | ||||||
|  |         n7["Option 2"] | ||||||
|  |         n8["fa:fa-car Option 3"] | ||||||
|  |   end | ||||||
|  |     A["Start"] -- Some text --> B("Continue") | ||||||
|  |     B --> C{"Evaluate"} | ||||||
|  |     C -- One --> D["Option 1"] | ||||||
|  |     C -- Two --> E["Option 2"] | ||||||
|  |     C -- Three --> F["fa:fa-car Option 3"] | ||||||
|  |     n1 -- One --> n2 | ||||||
|  |     n1 -- Two --> n3 | ||||||
|  |     n1 -- Three --> n4 | ||||||
|  |     n5 -- One --> n6 | ||||||
|  |     n5 -- Two --> n7 | ||||||
|  |     n5 -- Three --> n8 | ||||||
|  |     n1@{ shape: diam} | ||||||
|  |     n2@{ shape: rect} | ||||||
|  |     n3@{ shape: rect} | ||||||
|  |     n4@{ shape: rect} | ||||||
|  |     n5@{ shape: diam} | ||||||
|  |     n6@{ shape: rect} | ||||||
|  |     n7@{ shape: rect} | ||||||
|  |     n8@{ shape: rect} | ||||||
|  |  | ||||||
|  | `, | ||||||
|  |           { flowchart: { titleTopMargin: 0 } } | ||||||
|  |         ); | ||||||
|  |       }); | ||||||
|  |  | ||||||
|  |       it('6088-5: should handle diamond shape intersections', () => { | ||||||
|  |         imgSnapshotTest( | ||||||
|  |           `--- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |     A{A} --> B & C | ||||||
|  |  | ||||||
|  | `, | ||||||
|  |           { flowchart: { titleTopMargin: 0 } } | ||||||
|  |         ); | ||||||
|  |       }); | ||||||
|  |       it('6088-6: should handle diamond shape intersections', () => { | ||||||
|  |         imgSnapshotTest( | ||||||
|  |           `--- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |     A{A} --> B & C | ||||||
|  |     subgraph "subbe" | ||||||
|  |       A | ||||||
|  |     end | ||||||
|  |  | ||||||
| `, | `, | ||||||
|           { flowchart: { titleTopMargin: 0 } } |           { flowchart: { titleTopMargin: 0 } } | ||||||
|         ); |         ); | ||||||
|   | |||||||
| @@ -12,7 +12,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -30,7 +29,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -47,7 +45,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       C -->|Two| E[iPhone] |       C -->|Two| E[iPhone] | ||||||
|       C -->|Three| F[Car] |       C -->|Three| F[Car] | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -62,7 +60,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       C -->|Two| E[\\iPhone\\] |       C -->|Two| E[\\iPhone\\] | ||||||
|       C -->|Three| F[Car] |       C -->|Three| F[Car] | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -78,7 +76,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       classDef processHead fill:#888888,color:white,font-weight:bold,stroke-width:3px,stroke:#001f3f |       classDef processHead fill:#888888,color:white,font-weight:bold,stroke-width:3px,stroke:#001f3f | ||||||
|       class 1A,1B,D,E processHead |       class 1A,1B,D,E processHead | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -107,7 +105,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       35(SAM.CommonFA.PopulationFME)-->39(SAM.CommonFA.ChargeDetails) |       35(SAM.CommonFA.PopulationFME)-->39(SAM.CommonFA.ChargeDetails) | ||||||
|       36(SAM.CommonFA.PremetricCost)-->39(SAM.CommonFA.ChargeDetails) |       36(SAM.CommonFA.PremetricCost)-->39(SAM.CommonFA.ChargeDetails) | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -178,7 +176,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       9a072290_1ec3_e711_8c5a_005056ad0002-->d6072290_1ec3_e711_8c5a_005056ad0002 |       9a072290_1ec3_e711_8c5a_005056ad0002-->d6072290_1ec3_e711_8c5a_005056ad0002 | ||||||
|       9a072290_1ec3_e711_8c5a_005056ad0002-->71082290_1ec3_e711_8c5a_005056ad0002 |       9a072290_1ec3_e711_8c5a_005056ad0002-->71082290_1ec3_e711_8c5a_005056ad0002 | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -187,7 +185,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       ` |       ` | ||||||
|     graph TB;subgraph "number as labels";1;end; |     graph TB;subgraph "number as labels";1;end; | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -199,7 +197,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|         a1-->a2 |         a1-->a2 | ||||||
|       end |       end | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -211,7 +209,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|         a1-->a2 |         a1-->a2 | ||||||
|       end |       end | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -246,7 +244,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       style foo fill:#F99,stroke-width:2px,stroke:#F0F,color:darkred |       style foo fill:#F99,stroke-width:2px,stroke:#F0F,color:darkred | ||||||
|       style bar fill:#999,stroke-width:10px,stroke:#0F0,color:blue |       style bar fill:#999,stroke-width:10px,stroke:#0F0,color:blue | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -348,7 +346,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       sid-7CE72B24-E0C1-46D3-8132-8BA66BE05AA7-->sid-4DA958A0-26D9-4D47-93A7-70F39FD7D51A; |       sid-7CE72B24-E0C1-46D3-8132-8BA66BE05AA7-->sid-4DA958A0-26D9-4D47-93A7-70F39FD7D51A; | ||||||
|       sid-7CE72B24-E0C1-46D3-8132-8BA66BE05AA7-->sid-4FC27B48-A6F9-460A-A675-021F5854FE22; |       sid-7CE72B24-E0C1-46D3-8132-8BA66BE05AA7-->sid-4FC27B48-A6F9-460A-A675-021F5854FE22; | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, fontFamily: 'courier' } |       { look: 'handDrawn', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -364,7 +362,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         listUrl: false, |         listUrl: false, | ||||||
|         listId: 'color styling', |         listId: 'color styling', | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
| @@ -390,7 +387,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         listUrl: false, |         listUrl: false, | ||||||
|         listId: 'color styling', |         listId: 'color styling', | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
| @@ -411,7 +407,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -435,7 +430,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -457,7 +451,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -471,7 +464,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -485,7 +477,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -500,7 +491,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -527,7 +517,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       class A someclass;`, |       class A someclass;`, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -544,7 +533,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       C -->|Two| E[iPhone] |       C -->|Two| E[iPhone] | ||||||
|       C -->|Three| F[fa:fa-car Car] |       C -->|Three| F[fa:fa-car Car] | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, flowchart: { nodeSpacing: 50 }, fontFamily: 'courier' } |       { look: 'handDrawn', flowchart: { nodeSpacing: 50 }, fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -560,7 +549,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { rankSpacing: '100' }, |         flowchart: { rankSpacing: '100' }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -578,7 +566,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -603,7 +590,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       click E "notes://do-your-thing/id" "other protocol test" |       click E "notes://do-your-thing/id" "other protocol test" | ||||||
|       click F "javascript:alert('test')" "script test" |       click F "javascript:alert('test')" "script test" | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, securityLevel: 'loose', fontFamily: 'courier' } |       { look: 'handDrawn', securityLevel: 'loose', fontFamily: 'courier' } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -623,7 +610,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       click B "index.html#link-clicked" "link test" |       click B "index.html#link-clicked" "link test" | ||||||
|       click D testClick "click test" |       click D testClick "click test" | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, flowchart: { htmlLabels: true } } |       { look: 'handDrawn', flowchart: { htmlLabels: true } } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -645,7 +632,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -664,7 +650,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       class A myClass1 |       class A myClass1 | ||||||
|       class D myClass2 |       class D myClass2 | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, flowchart: { htmlLabels: true } } |       { look: 'handDrawn', flowchart: { htmlLabels: true } } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -682,7 +668,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -711,7 +696,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -728,7 +712,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -752,7 +735,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: false }, |         flowchart: { htmlLabels: false }, | ||||||
|         fontFamily: 'courier', |         fontFamily: 'courier', | ||||||
|       } |       } | ||||||
| @@ -769,7 +751,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       C -->|Two| E[iPhone] |       C -->|Two| E[iPhone] | ||||||
|       C -->|Three| F[fa:fa-car Car] |       C -->|Three| F[fa:fa-car Car] | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, flowchart: { diagramPadding: 0 } } |       { look: 'handDrawn', flowchart: { diagramPadding: 0 } } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
| @@ -804,7 +786,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `graph TD |       `graph TD | ||||||
|         a["<strong>Haiya</strong>"]-->b |         a["<strong>Haiya</strong>"]-->b | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, htmlLabels: false, flowchart: { htmlLabels: false } } |       { look: 'handDrawn', htmlLabels: false, flowchart: { htmlLabels: false } } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|   it('FDH37: should render non-escaped with html labels', () => { |   it('FDH37: should render non-escaped with html labels', () => { | ||||||
| @@ -814,7 +796,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -830,7 +811,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       C -->|Two| E[iPhone] |       C -->|Two| E[iPhone] | ||||||
|       C -->|Three| F[fa:fa-car Car] |       C -->|Three| F[fa:fa-car Car] | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, flowchart: { useMaxWidth: true } } |       { look: 'handDrawn', flowchart: { useMaxWidth: true } } | ||||||
|     ); |     ); | ||||||
|     cy.get('svg').should((svg) => { |     cy.get('svg').should((svg) => { | ||||||
|       expect(svg).to.have.attr('width', '100%'); |       expect(svg).to.have.attr('width', '100%'); | ||||||
| @@ -853,7 +834,7 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       C -->|Two| E[iPhone] |       C -->|Two| E[iPhone] | ||||||
|       C -->|Three| F[fa:fa-car Car] |       C -->|Three| F[fa:fa-car Car] | ||||||
|       `, |       `, | ||||||
|       { look: 'handDrawn', handDrawnSeed: 1, flowchart: { useMaxWidth: false } } |       { look: 'handDrawn', flowchart: { useMaxWidth: false } } | ||||||
|     ); |     ); | ||||||
|     cy.get('svg').should((svg) => { |     cy.get('svg').should((svg) => { | ||||||
|       // const height = parseFloat(svg.attr('height')); |       // const height = parseFloat(svg.attr('height')); | ||||||
| @@ -874,7 +855,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -904,7 +884,6 @@ describe('Flowchart HandDrawn', () => { | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -919,7 +898,6 @@ graph TD | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -937,7 +915,6 @@ graph TD | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -977,7 +954,6 @@ graph TD | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -999,7 +975,6 @@ graph TD | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -1016,7 +991,6 @@ graph TD | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -1032,7 +1006,6 @@ graph TD | |||||||
|       `, |       `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         htmlLabels: true, |         htmlLabels: true, | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
| @@ -1051,7 +1024,6 @@ graph TD | |||||||
|     `, |     `, | ||||||
|       { |       { | ||||||
|         look: 'handDrawn', |         look: 'handDrawn', | ||||||
|         handDrawnSeed: 1, |  | ||||||
|         flowchart: { htmlLabels: true }, |         flowchart: { htmlLabels: true }, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
|       } |       } | ||||||
|   | |||||||
							
								
								
									
										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'); |       const style = svg.attr('style'); | ||||||
|       expect(style).to.match(/^max-width: [\d.]+px;$/); |       expect(style).to.match(/^max-width: [\d.]+px;$/); | ||||||
|       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join('')); |       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join('')); | ||||||
|       expect(maxWidthValue).to.be.within(446 * 0.95 - 1, 446 * 1.05); |       expect(maxWidthValue).to.be.within(417 * 0.95, 417 * 1.05); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|   it('8: should render a flowchart when useMaxWidth is false', () => { |   it('8: should render a flowchart when useMaxWidth is false', () => { | ||||||
| @@ -118,7 +118,7 @@ describe('Flowchart v2', () => { | |||||||
|       const width = parseFloat(svg.attr('width')); |       const width = parseFloat(svg.attr('width')); | ||||||
|       // use within because the absolute value can be slightly different depending on the environment ±5% |       // 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(height).to.be.within(446 * 0.95, 446 * 1.05); | ||||||
|       expect(width).to.be.within(446 * 0.95 - 1, 446 * 1.05); |       expect(width).to.be.within(417 * 0.95, 417 * 1.05); | ||||||
|       expect(svg).to.not.have.attr('style'); |       expect(svg).to.not.have.attr('style'); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
| @@ -1052,5 +1052,65 @@ end | |||||||
|         } |         } | ||||||
|       ); |       ); | ||||||
|     }); |     }); | ||||||
|  |     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 } }, | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  |   describe('New @ sytax for node metadata edge cases', () => { | ||||||
|  |     it('should be possible to use @  syntax to add labels on multi nodes', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `flowchart TB | ||||||
|  |        n2["label for n2"] &   n4@{ label: "labe for n4"}   & n5@{ label: "labe for n5"} | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('should be possible to use @  syntax to add labels with trail spaces and &', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `flowchart TB | ||||||
|  |        n2["label for n2"] &   n4@{ label: "labe for n4"}   & n5@{ label: "labe for n5"}    | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('should be possible to use @  syntax to add labels with trail spaces', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `flowchart TB | ||||||
|  |        n2["label for n2"] | ||||||
|  |        n4@{ label: "labe for n4"} | ||||||
|  |        n5@{ label: "labe for n5"}   | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('should be possible to use @  syntax to add labels with trail spaces and edge/link', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `flowchart TD | ||||||
|  |     A["A"] --> B["for B"] &    C@{ label: "for c"} & E@{label : "for E"}   | ||||||
|  |     D@{label: "for D"}      | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										143
									
								
								cypress/integration/rendering/iconShape.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										143
									
								
								cypress/integration/rendering/iconShape.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,143 @@ | |||||||
|  | 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); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | describe('Test colored iconShape', () => { | ||||||
|  |   it('with no styles', () => { | ||||||
|  |     let flowchartCode = `flowchart TB\n`; | ||||||
|  |     const icon = 'fluent-emoji:tropical-fish'; | ||||||
|  |     flowchartCode += `  nA --> nAA@{ icon: '${icon}', form: 'square', label: 'icon with color' }\n`; | ||||||
|  |     imgSnapshotTest(flowchartCode); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('with styles', () => { | ||||||
|  |     let flowchartCode = `flowchart TB\n`; | ||||||
|  |     const icon = 'fluent-emoji:tropical-fish'; | ||||||
|  |     flowchartCode += `  nA --> nAA@{ icon: '${icon}', form: 'square', label: 'icon with color' }\n`; | ||||||
|  |     flowchartCode += `  style nAA fill:#f9f,stroke:#333,stroke-width:4px \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 }); | ||||||
|  |         }); | ||||||
|  |       }); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
							
								
								
									
										136
									
								
								cypress/integration/rendering/kanban.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								cypress/integration/rendering/kanban.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,136 @@ | |||||||
|  | import { imgSnapshotTest } from '../../helpers/util.ts'; | ||||||
|  |  | ||||||
|  | describe('Kanban diagram', () => { | ||||||
|  |   it('1: should render a kanban with a single section', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     docs[Create Documentation] | ||||||
|  |     docs[Create Blog about the new diagram] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('2: should render a kanban with multiple sections', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     docs[Create Documentation] | ||||||
|  |   id2 | ||||||
|  |     docs[Create Blog about the new diagram] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('3: should render a kanban with a single wrapping node', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     id2[Title of diagram is more than 100 chars when user duplicates diagram with 100 char, wrapping] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('4: should handle the height of a section with a wrapping node at the end', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     id2[One line] | ||||||
|  |     id3[Title of diagram is more than 100 chars when user duplicates diagram with 100 char, wrapping] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('5: should handle the height of a section with a wrapping node at the top', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     id2[Title of diagram is more than 100 chars when user duplicates diagram with 100 char, wrapping] | ||||||
|  |     id3[One line] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('6: should handle the height of a section with a wrapping node in the middle', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     id2[One line] | ||||||
|  |     id3[Title of diagram is more than 100 chars when user duplicates diagram with 100 char, wrapping] | ||||||
|  |     id4[One line] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('6: should handle assigments', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     docs[Create Documentation] | ||||||
|  |   id2[In progress] | ||||||
|  |     docs[Create Blog about the new diagram]@{ assigned: 'knsv' } | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('7: should handle prioritization', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id2[In progress] | ||||||
|  |     vh[Very High]@{ priority: 'Very High' } | ||||||
|  |     h[High]@{ priority: 'High' } | ||||||
|  |     m[Default priority] | ||||||
|  |     l[Low]@{ priority: 'Low' } | ||||||
|  |     vl[Very Low]@{ priority: 'Very Low' } | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('7: should handle external tickets', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     docs[Create Documentation] | ||||||
|  |   id2[In progress] | ||||||
|  |     docs[Create Blog about the new diagram]@{ ticket: MC-2037 } | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('8: should handle assignments, prioritization and tickets ids in the same item', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `kanban | ||||||
|  |   id2[In progress] | ||||||
|  |     docs[Create Blog about the new diagram]@{ priority: 'Very Low', ticket: MC-2037, assigned: 'knsv' } | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('10: Full example', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `--- | ||||||
|  | config: | ||||||
|  |   kanban: | ||||||
|  |     ticketBaseUrl: 'https://abc123.atlassian.net/browse/#TICKET#' | ||||||
|  | --- | ||||||
|  | kanban | ||||||
|  |   id1[Todo] | ||||||
|  |     docs[Create Documentation] | ||||||
|  |     docs[Create Blog about the new diagram] | ||||||
|  |   id7[In progress] | ||||||
|  |     id6[Create renderer so that it works in all cases. We also add som extra text here for testing purposes. And some more just for the extra flare.] | ||||||
|  |     id8[Design grammar]@{ assigned: 'knsv' } | ||||||
|  |   id9[Ready for deploy] | ||||||
|  |   id10[Ready for test] | ||||||
|  |   id11[Done] | ||||||
|  |     id5[define getData] | ||||||
|  |     id2[Title of diagram is more than 100 chars when user duplicates diagram with 100 char]@{ ticket: MC-2036, priority: 'Very High'} | ||||||
|  |     id3[Update DB function]@{ ticket: MC-2037, assigned: knsv, priority: 'High' } | ||||||
|  |     id4[Create parsing tests]@{ ticket: MC-2038, assigned: 'K.Sveidqvist', priority: 'High' } | ||||||
|  |     id66[last item]@{ priority: 'Very Low', assigned: 'knsv' } | ||||||
|  |   id12[Can't reproduce] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
							
								
								
									
										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 }); | ||||||
|  |         }); | ||||||
|  |       }); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
							
								
								
									
										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> | ||||||
| @@ -10,6 +10,10 @@ | |||||||
|       href="https://cdn.jsdelivr.net/npm/@mdi/font@6.9.96/css/materialdesignicons.min.css" |       href="https://cdn.jsdelivr.net/npm/@mdi/font@6.9.96/css/materialdesignicons.min.css" | ||||||
|       rel="stylesheet" |       rel="stylesheet" | ||||||
|     /> |     /> | ||||||
|  |     <link | ||||||
|  |       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css" | ||||||
|  |       rel="stylesheet" | ||||||
|  |     /> | ||||||
|     <link |     <link | ||||||
|       href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap" |       href="https://fonts.googleapis.com/css?family=Noto+Sans+SC&display=swap" | ||||||
|       rel="stylesheet" |       rel="stylesheet" | ||||||
| @@ -34,6 +38,7 @@ | |||||||
|         /* background: rgb(221, 208, 208); */ |         /* background: rgb(221, 208, 208); */ | ||||||
|         /* background: #333; */ |         /* background: #333; */ | ||||||
|         font-family: 'Arial'; |         font-family: 'Arial'; | ||||||
|  |         /* color: white; */ | ||||||
|         /* font-size: 18px !important; */ |         /* font-size: 18px !important; */ | ||||||
|       } |       } | ||||||
|  |  | ||||||
| @@ -74,101 +79,354 @@ | |||||||
|         font-size: 72px; |         font-size: 72px; | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  |       pre { | ||||||
|  |         width: 100%; | ||||||
|  |       } | ||||||
|  |  | ||||||
|       /* tspan { |       /* tspan { | ||||||
|               font-size: 6px !important; |               font-size: 6px !important; | ||||||
|             } */ |             } */ | ||||||
|  |       /* .flowchart-link { | ||||||
|  |         stroke-dasharray: 4, 4 !important; | ||||||
|  |         animation: flow 1s linear infinite; | ||||||
|  |         animation: dashdraw 4.93282s linear infinite; | ||||||
|  |         stroke-width: 2px !important; | ||||||
|  |       } */ | ||||||
|  |  | ||||||
|  |       @keyframes dashdraw { | ||||||
|  |         from { | ||||||
|  |           stroke-dashoffset: 0; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       /*stroke-width:2;stroke-dasharray:10.000000,9.865639;stroke-dashoffset:-198.656393;animation:    4.932820s linear infinite;*/ | ||||||
|  |       /* stroke-width:2;stroke-dasharray:10.000000,9.865639;stroke-dashoffset:-198.656393;animation: dashdraw 4.932820s linear infinite;*/ | ||||||
|     </style> |     </style> | ||||||
|   </head> |   </head> | ||||||
|  |  | ||||||
|   <body> |   <body> | ||||||
|     <div class="flex"> |     <pre id="diagram4" class="mermaid"> | ||||||
|       <pre id="diagram" class="mermaid"> |  | ||||||
| --- |  | ||||||
|   title: hello2 |  | ||||||
|   config: |  | ||||||
|     look: handDrawn |  | ||||||
|     layout: elk |  | ||||||
|     elk: |  | ||||||
|         nodePlacementStrategy: BRANDES_KOEPF |  | ||||||
| --- |  | ||||||
|       flowchart LR |       flowchart LR | ||||||
|   A[Start] --Some text--> B(Continue) |         AB["apa@apa@"] --> B(("`apa@apa`")) | ||||||
|   B --> C{Evaluate} |  | ||||||
|   C -- One --> D[Option 1] |  | ||||||
|   C -- Two --> E[Option 2] |  | ||||||
|   C -- Three --> F[fa:fa-car Option 3] |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| </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> | ||||||
|  |     <pre id="diagram4" class="mermaid"> | ||||||
|     <pre id="diagram3" class="mermaid2"> |       flowchart | ||||||
|  |         D(("for D")) | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid"> | ||||||
|       flowchart LR |       flowchart LR | ||||||
|     A:::foo & B:::bar --> C:::foobar |         A e1@==> B | ||||||
|     classDef foo stroke:#f00 |         e1@{ animate: true} | ||||||
|     classDef bar stroke:#0f0 |     </pre> | ||||||
|     classDef ash color:red |     <pre id="diagram4" class="mermaid"> | ||||||
|     class C ash | flowchart LR | ||||||
|     style C stroke:#00f, fill:black |   A e1@--> B | ||||||
|  |   classDef animate stroke-width:2,stroke-dasharray:10\,8,stroke-dashoffset:-180,animation: edge-animation-frame 6s linear infinite, stroke-linecap: round | ||||||
|  |   class e1 animate | ||||||
|  |     </pre> | ||||||
|  |     <h2>infinite</h2> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  |   A e1@--> B | ||||||
|  |   classDef animate stroke-dasharray: 9\,5,stroke-dashoffset: 900,animation: dash 25s linear infinite; | ||||||
|  |   class e1 animate | ||||||
|  |     </pre> | ||||||
|  |     <h2>Mermaid - edge-animation-slow</h2> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  |   A e1@--> B | ||||||
|  | e1@{ animation: fast} | ||||||
|  |     </pre> | ||||||
|  |     <h2>Mermaid - edge-animation-fast</h2> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  |   A e1@--> B | ||||||
|  |   classDef animate stroke-dasharray: 1000,stroke-dashoffset: 1000,animation: dash 10s linear; | ||||||
|  |   class e1 edge-animation-fast | ||||||
|     </pre> |     </pre> | ||||||
|  |  | ||||||
|     <pre id="diagram4" class="mermaid2"> |     <pre id="diagram4" class="mermaid2"> | ||||||
|       stateDiagram |  | ||||||
|     A:::foo | info    </pre | ||||||
|     B:::bar --> C:::foobar |     > | ||||||
|     classDef foo stroke:#f00 |     <pre id="diagram4" class="mermaid2"> | ||||||
|     classDef bar stroke:#0f0 | --- | ||||||
|     style C stroke:#00f, fill:black, color:white | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  |       flowchart LR | ||||||
|  |       a | ||||||
|  |       subgraph s0["APA"] | ||||||
|  |       subgraph s8["APA"] | ||||||
|  |       subgraph s1["APA"] | ||||||
|  |         D{"X"} | ||||||
|  |         E[Q] | ||||||
|  |       end | ||||||
|  |       subgraph s3["BAPA"] | ||||||
|  |         F[Q] | ||||||
|  |         I | ||||||
|  |       end | ||||||
|  |             D --> I | ||||||
|  |             D --> I | ||||||
|  |             D --> I | ||||||
|  |  | ||||||
|  |       I{"X"} | ||||||
|  |       end | ||||||
|  |       end | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  |       flowchart LR | ||||||
|  |       a | ||||||
|  |         D{"Use the editor"} | ||||||
|  |  | ||||||
|  |       D -- Mermaid js --> I{"fa:fa-code Text"} | ||||||
|  |       D-->I | ||||||
|  |       D-->I | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |  subgraph s1["Untitled subgraph"] | ||||||
|  |         n1["Evaluate"] | ||||||
|  |         n2["Option 1"] | ||||||
|  |         n3["Option 2"] | ||||||
|  |         n4["fa:fa-car Option 3"] | ||||||
|  |   end | ||||||
|  |  subgraph s2["Untitled subgraph"] | ||||||
|  |         n5["Evaluate"] | ||||||
|  |         n6["Option 1"] | ||||||
|  |         n7["Option 2"] | ||||||
|  |         n8["fa:fa-car Option 3"] | ||||||
|  |   end | ||||||
|  |     A["Start"] -- Some text --> B("Continue") | ||||||
|  |     B --> C{"Evaluate"} | ||||||
|  |     C -- One --> D["Option 1"] | ||||||
|  |     C -- Two --> E["Option 2"] | ||||||
|  |     C -- Three --> F["fa:fa-car Option 3"] | ||||||
|  |     n1 -- One --> n2 | ||||||
|  |     n1 -- Two --> n3 | ||||||
|  |     n1 -- Three --> n4 | ||||||
|  |     n5 -- One --> n6 | ||||||
|  |     n5 -- Two --> n7 | ||||||
|  |     n5 -- Three --> n8 | ||||||
|  |     n1@{ shape: diam} | ||||||
|  |     n2@{ shape: rect} | ||||||
|  |     n3@{ shape: rect} | ||||||
|  |     n4@{ shape: rect} | ||||||
|  |     n5@{ shape: diam} | ||||||
|  |     n6@{ shape: rect} | ||||||
|  |     n7@{ shape: rect} | ||||||
|  |     n8@{ shape: rect} | ||||||
|  |  | ||||||
|     </pre> |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |  subgraph s1["Untitled subgraph"] | ||||||
|  |         n1["Evaluate"] | ||||||
|  |         n2["Option 1"] | ||||||
|  |   end | ||||||
|  |     n1 -- One --> n2 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |     A{A} --> B & C | ||||||
|  | </pre | ||||||
|  |     > | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |     A{A} --> B & C | ||||||
|  |     subgraph "subbe" | ||||||
|  |       A | ||||||
|  |     end | ||||||
|  | </pre | ||||||
|  |     > | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   layout: elk | ||||||
|  | --- | ||||||
|  | flowchart LR | ||||||
|  |     n2@{ shape: rect} | ||||||
|  |     n3@{ shape: rect} | ||||||
|  |     n4@{ shape: rect} | ||||||
|  |     A["Start"] -- Some text --> B("Continue") | ||||||
|  |     B --> C{"Evaluate"} | ||||||
|  |     C -- One --> D["Option 1"] | ||||||
|  |     C -- Two --> E["Option 2"] | ||||||
|  |     C -- Three --> F["fa:fa-car Option 3"] | ||||||
|  |     %% C@{ shape: hexagon} | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   kanban: | ||||||
|  |     ticketBaseUrl: 'https://github.com/your-repo/issues/#TICKET#' | ||||||
|  | --- | ||||||
|  | kanban | ||||||
|  |   Backlog | ||||||
|  |     task1[📝 Define project requirements]@{ ticket: a101 } | ||||||
|  |   To Do | ||||||
|  |     task2[🔍 Research technologies]@{ ticket: a102 } | ||||||
|  |   Review | ||||||
|  |     task4[🔍 Code review for login feature]@{ ticket: a104 } | ||||||
|  |   Done | ||||||
|  |     task5[✅ Deploy initial version]@{ ticket: a105 } | ||||||
|  |   In Progress | ||||||
|  |     task3[💻 Develop login feature]@{ ticket: 103 } | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Default] --> A@{ icon: 'fa:bell', form: 'rounded' } | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Style] --> A@{ icon: 'fa:bell', form: 'rounded' } | ||||||
|  | style A fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Class] --> A@{ icon: 'fa:bell', form: 'rounded' } | ||||||
|  | A:::AClass | ||||||
|  | classDef AClass fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  |   nA[Class] --> A@{ icon: 'logos:aws', form: 'rounded' } | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Default] --> A@{ icon: 'fa:bell', form: 'square' } | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Style] --> A@{ icon: 'fa:bell', form: 'square' } | ||||||
|  | style A fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Class] --> A@{ icon: 'fa:bell', form: 'square' } | ||||||
|  | A:::AClass | ||||||
|  | classDef AClass fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  |   nA[Class] --> A@{ icon: 'logos:aws', form: 'square' } | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Default] --> A@{ icon: 'fa:bell', form: 'circle' } | ||||||
|  |  | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Style] --> A@{ icon: 'fa:bell', form: 'circle' } | ||||||
|  | style A fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  | nA[Class] --> A@{ icon: 'fa:bell', form: 'circle' } | ||||||
|  | A:::AClass | ||||||
|  | classDef AClass fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  |   nA[Class] --> A@{ icon: 'logos:aws', form: 'circle' } | ||||||
|  |   A:::AClass | ||||||
|  |   classDef AClass fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | flowchart LR | ||||||
|  |   nA[Style] --> A@{ icon: 'logos:aws', form: 'circle' } | ||||||
|  |   style A fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | kanban | ||||||
|  |   id2[In progress] | ||||||
|  |     docs[Create Blog about the new diagram]@{ priority: 'Very Low', ticket: MC-2037, assigned: 'knsv' } | ||||||
|  |     </pre> | ||||||
|  |     <pre id="diagram4" class="mermaid2"> | ||||||
|  | --- | ||||||
|  | config: | ||||||
|  |   kanban: | ||||||
|  |     ticketBaseUrl: 'https://mermaidchart.atlassian.net/browse/#TICKET#' | ||||||
|  |     # sectionWidth: 300 | ||||||
|  | --- | ||||||
|  | kanban | ||||||
|  |   Todo | ||||||
|  |     [Create Documentation] | ||||||
|  |     docs[Create Blog about the new diagram] | ||||||
|  |   id7[In progress] | ||||||
|  |     id6[Create renderer so that it works in all cases. We also add som extra text here for testing purposes. And some more just for the extra flare.] | ||||||
|  |   id9[Ready for deploy] | ||||||
|  |     id8[Design grammar]@{ assigned: 'knsv' } | ||||||
|  |   id10[Ready for test] | ||||||
|  |     id4[Create parsing tests]@{ ticket: MC-2038, assigned: 'K.Sveidqvist', priority: 'High' } | ||||||
|  |     id66[last item]@{ priority: 'Very Low', assigned: 'knsv' } | ||||||
|  |   id11[Done] | ||||||
|  |     id5[define getData] | ||||||
|  |     id2[Title of diagram is more than 100 chars when user duplicates diagram with 100 char]@{ ticket: MC-2036, priority: 'Very High'} | ||||||
|  |     id3[Update DB function]@{ ticket: MC-2037, assigned: knsv, priority: 'High' } | ||||||
|  |  | ||||||
|  |   id12[Can't reproduce] | ||||||
|  |     id3[Weird flickering in Firefox] | ||||||
|  |     </pre> | ||||||
|     <script type="module"> |     <script type="module"> | ||||||
|       import mermaid from './mermaid.esm.mjs'; |       import mermaid from './mermaid.esm.mjs'; | ||||||
|       import layouts from './mermaid-layout-elk.esm.mjs'; |       import layouts from './mermaid-layout-elk.esm.mjs'; | ||||||
|  |  | ||||||
|  |       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: 'logos', | ||||||
|  |           loader: () => | ||||||
|  |             fetch('https://unpkg.com/@iconify-json/logos@1/icons.json').then((res) => res.json()), | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           name: 'fa', | ||||||
|  |           loader: () => staticBellIconPack, | ||||||
|  |         }, | ||||||
|  |       ]); | ||||||
|       mermaid.registerLayoutLoaders(layouts); |       mermaid.registerLayoutLoaders(layouts); | ||||||
|       mermaid.parseError = function (err, hash) { |       mermaid.parseError = function (err, hash) { | ||||||
|         console.error('Mermaid error: ', err); |         console.error('Mermaid error: ', err); | ||||||
| @@ -176,8 +434,13 @@ flowchart LR | |||||||
|       window.callback = function () { |       window.callback = function () { | ||||||
|         alert('A callback was triggered'); |         alert('A callback was triggered'); | ||||||
|       }; |       }; | ||||||
|       mermaid.initialize({ |       function callback() { | ||||||
|  |         alert('It worked'); | ||||||
|  |       } | ||||||
|  |       await mermaid.initialize({ | ||||||
|         // theme: 'base', |         // theme: 'base', | ||||||
|  |         // theme: 'default', | ||||||
|  |         // theme: 'forest', | ||||||
|         // handDrawnSeed: 12, |         // handDrawnSeed: 12, | ||||||
|         // look: 'handDrawn', |         // look: 'handDrawn', | ||||||
|         // 'elk.nodePlacement.strategy': 'NETWORK_SIMPLEX', |         // 'elk.nodePlacement.strategy': 'NETWORK_SIMPLEX', | ||||||
| @@ -186,21 +449,25 @@ flowchart LR | |||||||
|         // layout: 'fixed', |         // layout: 'fixed', | ||||||
|         // htmlLabels: false, |         // htmlLabels: false, | ||||||
|         flowchart: { titleTopMargin: 10 }, |         flowchart: { titleTopMargin: 10 }, | ||||||
|  |  | ||||||
|         // fontFamily: 'Caveat', |         // fontFamily: 'Caveat', | ||||||
|         // fontFamily: 'Kalam', |         // fontFamily: 'Kalam', | ||||||
|         // fontFamily: 'courier', |         // fontFamily: 'courier', | ||||||
|  |         fontFamily: 'arial', | ||||||
|         sequence: { |         sequence: { | ||||||
|           actorFontFamily: 'courier', |           actorFontFamily: 'courier', | ||||||
|           noteFontFamily: 'courier', |           noteFontFamily: 'courier', | ||||||
|           messageFontFamily: 'courier', |           messageFontFamily: 'courier', | ||||||
|         }, |         }, | ||||||
|  |         kanban: { | ||||||
|  |           htmlLabels: false, | ||||||
|  |         }, | ||||||
|         fontSize: 12, |         fontSize: 12, | ||||||
|         logLevel: 0, |         logLevel: 0, | ||||||
|         securityLevel: 'loose', |         securityLevel: 'loose', | ||||||
|  |         callback, | ||||||
|       }); |       }); | ||||||
|       function callback() { |  | ||||||
|         alert('It worked'); |  | ||||||
|       } |  | ||||||
|       mermaid.parseError = function (err, hash) { |       mermaid.parseError = function (err, hash) { | ||||||
|         console.error('In parse error:'); |         console.error('In parse error:'); | ||||||
|         console.error(err); |         console.error(err); | ||||||
|   | |||||||
							
								
								
									
										141
									
								
								cypress/platform/saurabh.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								cypress/platform/saurabh.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | |||||||
|  | <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 | ||||||
|  |           A --> A | ||||||
|  |           subgraph B | ||||||
|  |             B1 --> B1 | ||||||
|  |           end | ||||||
|  |           subgraph C | ||||||
|  |             subgraph C1 | ||||||
|  |               C2 --> C2 | ||||||
|  |               subgraph D | ||||||
|  |                 D1 --> D1 | ||||||
|  |               end | ||||||
|  |               D --> D | ||||||
|  |             end | ||||||
|  |             C1 --> C1 | ||||||
|  |           end | ||||||
|  |  | ||||||
|  |     </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> | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										663
									
								
								cypress/platform/yari.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										663
									
								
								cypress/platform/yari.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,663 @@ | |||||||
|  | <html> | ||||||
|  |   <body> | ||||||
|  |     <h1 class="header">Class Nodes</h1> | ||||||
|  |     <div class="node-showcase"> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Basic Class</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |             config: | ||||||
|  |               htmlLabels: false | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class _Duck_ { | ||||||
|  |             +String beakColor | ||||||
|  |             _+_swim_()a_ | ||||||
|  |             __+quack() test__ | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Basic Class</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           config: | ||||||
|  |             htmlLabels: false | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class Class10:::exClass2 { | ||||||
|  |             int[] id | ||||||
|  |             List~int~ ids | ||||||
|  |             test(List~int~ ids) List~bool~ | ||||||
|  |             testArray() bool[] | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Basic Class</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           flowchart TD | ||||||
|  |             Start --> Stop | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Complex Class</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |                 classDiagram | ||||||
|  |                 class Square~Shape~{ | ||||||
|  |                   int id | ||||||
|  |                   List~int~ position | ||||||
|  |                   setPoints(List~int~ points) | ||||||
|  |                   getPoints() List~int~ | ||||||
|  |                 } | ||||||
|  |            | ||||||
|  |           Square : -List~string~ messages | ||||||
|  |           Square : +setMessages(List~string~ messages) | ||||||
|  |           Square : +getMessages() List~string~ | ||||||
|  |           Square : +getDistanceMatrix() List~List~int~~ | ||||||
|  |               </pre | ||||||
|  |         > | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>No Attributes</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>No Methods</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Only Class Name</h2> | ||||||
|  |         <p>Empty line as attribute</p> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |             config: | ||||||
|  |               class: | ||||||
|  |                 hideEmptyMembersBox: false | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |              | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Visibility and Types</h2> | ||||||
|  |         <p>(Further tilde testing)</p> | ||||||
|  |         <div class="mermaid"> | ||||||
|  |           classDiagram class Duck { ~interface~~~ +String beakColor #swim() ~quack()~~~ | ||||||
|  |           -test()~~~~~~~ +deposit(amount) bool } | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Additional Classifiers</h2> | ||||||
|  |         <p>(* Abstract | $ Static)</p> | ||||||
|  |         <div class="mermaid"> | ||||||
|  |           classDiagram class Square~Shape~ { int id* List~int~ position* setPoints(List~int~points)* | ||||||
|  |           getPoints()* List~int~ } Square : -List~string~ messages$ Square : | ||||||
|  |           +setMessages(List~string~ messages)* Square : +getMessages()$ List~string~ Square : | ||||||
|  |           +getDistanceMatrix() List~List~int~~$ | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Label</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Animal~test~["Animal with a label"] | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Spacing</h2> | ||||||
|  |         <p>(Fix ensures consistent spacing rules)</p> | ||||||
|  |         <p>(No space or single space?)</p> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class ClassName { | ||||||
|  |           -attribute:type | ||||||
|  |           -            attribute : type | ||||||
|  |                test | ||||||
|  |            | ||||||
|  |           + GetAttribute() type                  | ||||||
|  |           +     GetAttribute() type | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Annotation</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Shape | ||||||
|  |           <<interface>> Shape | ||||||
|  |           Shape : noOfVertices | ||||||
|  |           Shape : draw() | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Long Class Name Text</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class ThisIsATestForALongClassName { | ||||||
|  |             <<interface>> | ||||||
|  |             noOfLetters | ||||||
|  |             delete() | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Long Annotation Text</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Shape | ||||||
|  |           <<superlongannotationtext>> Shape | ||||||
|  |           Shape : noOfVertices | ||||||
|  |           Shape : draw() | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Long Member Text</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Shape | ||||||
|  |           <<interface>> Shape | ||||||
|  |           Shape : noOfVertices | ||||||
|  |           Shape : longtexttestkeepgoingandgoing | ||||||
|  |           Shape : draw() | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Link</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Shape | ||||||
|  |           link Shape "https://www.github.com" "This is a tooltip for a link" | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Click</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Shape | ||||||
|  |           click Shape href "https://www.github.com" "This is a tooltip for a link" | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Hand Drawn</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           config: | ||||||
|  |             look: handDrawn | ||||||
|  |             htmlLabels: true | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class Hand { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |           style Hand fill:#f9f,stroke:#29f,stroke-width:2px | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Neutral Theme</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           config: | ||||||
|  |             theme: neutral | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Dark Theme</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           config: | ||||||
|  |             theme: dark | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Forest Theme</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           config: | ||||||
|  |             theme: forest | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Base Theme</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           config: | ||||||
|  |             theme: base | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Custom Theme</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           %%{ | ||||||
|  |             init: { | ||||||
|  |               'theme': 'base', | ||||||
|  |               'themeVariables': { | ||||||
|  |                 'primaryColor': '#BB2528', | ||||||
|  |                 'primaryTextColor': '#fff', | ||||||
|  |                 'primaryBorderColor': '#7C0000', | ||||||
|  |                 'lineColor': '#F83d29', | ||||||
|  |                 'secondaryColor': '#006100', | ||||||
|  |                 'tertiaryColor': '#fff' | ||||||
|  |               } | ||||||
|  |             } | ||||||
|  |           }%% | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |           Duck--Dog | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Styling within Diagram</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |           style Duck fill:#f9f,stroke:#333,stroke-width:8px | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Styling with classDef Statement</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Duck:::bold { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |  | ||||||
|  |           class Dog { | ||||||
|  |             +int numTeeth | ||||||
|  |             +bark() | ||||||
|  |           } | ||||||
|  |  | ||||||
|  |           cssClass "Duck,Dog" pink | ||||||
|  |  | ||||||
|  |           classDef pink fill:#f9f | ||||||
|  |           classDef default color:#f1e | ||||||
|  |           classDef bold stroke:#333,stroke-width:6px,color:#fff | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Styling with Class in Stylesheet</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Duck { | ||||||
|  |             +String beakColor | ||||||
|  |             +swim() | ||||||
|  |             +quack() | ||||||
|  |           } | ||||||
|  |           class Duck:::styleClass | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <h1 class="header">Diagram Testing</h1> | ||||||
|  |     <div class="diagram-showcase"> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Class Nodes Only</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           title: Animal example | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |               Animal : +int age | ||||||
|  |               Animal : +String gender | ||||||
|  |               Animal: +isMammal() | ||||||
|  |               Animal: +mate() | ||||||
|  |               class Duck{ | ||||||
|  |                   +String beakColor | ||||||
|  |                   +swim() | ||||||
|  |                   +quack() | ||||||
|  |               } | ||||||
|  |               class Fish{ | ||||||
|  |                   -int sizeInFeet | ||||||
|  |                   -canEat() | ||||||
|  |               } | ||||||
|  |               class Zebra{ | ||||||
|  |                   +bool is_wild | ||||||
|  |                   +run() | ||||||
|  |               } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Class Nodes LR</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           title: Animal example | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |               direction LR | ||||||
|  |               Animal : +int age | ||||||
|  |               Animal : +String gender | ||||||
|  |               Animal: +isMammal() | ||||||
|  |               Animal: +mate() | ||||||
|  |               class Duck{ | ||||||
|  |                   +String beakColor | ||||||
|  |                   +swim() | ||||||
|  |                   +quack() | ||||||
|  |               } | ||||||
|  |               class Fish{ | ||||||
|  |                   -int sizeInFeet | ||||||
|  |                   -canEat() | ||||||
|  |               } | ||||||
|  |               class Zebra{ | ||||||
|  |                   +bool is_wild | ||||||
|  |                   +run() | ||||||
|  |               } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Relations</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |             classA <|-- classB | ||||||
|  |             classC *-- classD | ||||||
|  |             classE o-- classF | ||||||
|  |             classG <-- classH | ||||||
|  |             classI -- classJ | ||||||
|  |             classK <.. classL | ||||||
|  |             classM <|.. classN | ||||||
|  |             classO .. classP | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Two Way Relation</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |           class Animal { | ||||||
|  |             int size | ||||||
|  |             walk() | ||||||
|  |           } | ||||||
|  |           class Zebra { | ||||||
|  |             int size | ||||||
|  |             walk() | ||||||
|  |           } | ||||||
|  |             Animal o--|> Zebra | ||||||
|  |  | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Relations with Labels</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |             classA <|-- classB : implements | ||||||
|  |             classC *-- classD : composition | ||||||
|  |             classE o-- classF : aggregation | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Cardinality / Multiplicity</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |             Customer "1" --> "*" Ticket | ||||||
|  |             Student "1" --> "1..*" Course | ||||||
|  |             Galaxy --> "many" Star : Contains | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Complex Relations with Theme</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           config: | ||||||
|  |             theme: forest | ||||||
|  |             look: handDrawns | ||||||
|  |             layout: elk | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |             direction RL | ||||||
|  |             class Student { | ||||||
|  |               -idCard : IdCard | ||||||
|  |             } | ||||||
|  |             class IdCard{ | ||||||
|  |               -id : int | ||||||
|  |               -name : string | ||||||
|  |             } | ||||||
|  |             class Bike{ | ||||||
|  |               -id : int | ||||||
|  |               -name : string | ||||||
|  |             } | ||||||
|  |             Student "1" o--o "1" IdCard : carries | ||||||
|  |             Student "1" o--o "1" Bike : rides | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Notes</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |             note "This is a general note" | ||||||
|  |             note for MyClass "This is a note for a class" | ||||||
|  |             class MyClass | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Namespaces</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |             namespace BaseShapes { | ||||||
|  |                 class Triangle | ||||||
|  |                 class Rectangle { | ||||||
|  |                   double width | ||||||
|  |                   double height | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Namespaces</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |             config: | ||||||
|  |               layout: elk | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           namespace Namespace1 { | ||||||
|  |             class C1 | ||||||
|  |             class C2 | ||||||
|  |           } | ||||||
|  |           C1 --> C2 | ||||||
|  |           class C3 | ||||||
|  |           class C4 | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Full Example</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |           title: Animal example | ||||||
|  |           config: | ||||||
|  |             layout: dagre | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |               note "From Duck till Zebra" | ||||||
|  |               Animal <|--|> Duck | ||||||
|  |               note for Duck "can fly<br>can swim<br>can dive<br>can help in debugging" | ||||||
|  |               Animal <|-- Fish | ||||||
|  |               Animal <|--|> Zebra | ||||||
|  |               Animal : +int age | ||||||
|  |               Animal : +String gender | ||||||
|  |               Animal: +isMammal() | ||||||
|  |               Animal: +mate() | ||||||
|  |               class Duck{ | ||||||
|  |                   +String beakColor | ||||||
|  |                   +swim() | ||||||
|  |                   +quack() | ||||||
|  |               } | ||||||
|  |               class Fish{ | ||||||
|  |                   -int sizeInFeet | ||||||
|  |                   -canEat() | ||||||
|  |               } | ||||||
|  |               class Zebra{ | ||||||
|  |                   +bool is_wild | ||||||
|  |                   +run() | ||||||
|  |               } | ||||||
|  |               cssClass "Duck" test | ||||||
|  |               classDef test fill:#f71 | ||||||
|  |               %%classDef default fill:#f93 | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <h2>Full Example</h2> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |             config: | ||||||
|  |               theme: forest | ||||||
|  |               look: handDrawn | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |           note for Outside "Note testing" | ||||||
|  |           namespace Test { | ||||||
|  |               class Outside | ||||||
|  |           } | ||||||
|  |           namespace BaseShapes { | ||||||
|  |               class Triangle | ||||||
|  |               class Rectangle { | ||||||
|  |                 double width | ||||||
|  |                 double height | ||||||
|  |               } | ||||||
|  |           } | ||||||
|  |           Outside <|--|> Rectangle | ||||||
|  |           style Triangle fill:#f9f,stroke:#333,stroke-width:4px | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           --- | ||||||
|  |             config: | ||||||
|  |               look: handDrawn | ||||||
|  |               layout: elk | ||||||
|  |           --- | ||||||
|  |           classDiagram | ||||||
|  |             Class01 "1" <|--|> "*" AveryLongClass : Cool | ||||||
|  |             <<interface>> Class01 | ||||||
|  |             Class03 "1" *-- "*" Class04 | ||||||
|  |             Class05 "1" o-- "many" Class06 | ||||||
|  |             Class07 "1" .. "*" Class08 | ||||||
|  |             Class09 "1" --> "*" C2 : Where am i? | ||||||
|  |             Class09 "*" --* "*" C3 | ||||||
|  |             Class09 "1" --|> "1" Class07 | ||||||
|  |             NewClass ()--() Class04 | ||||||
|  |             Class09 <|--|> AveryLongClass | ||||||
|  |             Class07  : equals() | ||||||
|  |             Class07  : Object[] elementData | ||||||
|  |             Class01  : size() | ||||||
|  |             Class01  : int chimp | ||||||
|  |             Class01  : int gorilla | ||||||
|  |             Class08 "1" <--> "*" C2: Cool label | ||||||
|  |             class Class10 { | ||||||
|  |               <<service>> | ||||||
|  |               int id | ||||||
|  |               test() | ||||||
|  |             } | ||||||
|  |             Class10 o--o AveryLongClass | ||||||
|  |             Class10 <--> Class07 | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |       <div class="test"> | ||||||
|  |         <pre class="mermaid"> | ||||||
|  |           classDiagram | ||||||
|  |             test ()--() test2 | ||||||
|  |         </pre> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     <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) { | ||||||
|  |         console.error('Mermaid error: ', err); | ||||||
|  |       }; | ||||||
|  |       mermaid.initialize(); | ||||||
|  |       mermaid.parseError = function (err, hash) { | ||||||
|  |         console.error('In parse error:'); | ||||||
|  |         console.error(err); | ||||||
|  |       }; | ||||||
|  |     </script> | ||||||
|  |   </body> | ||||||
|  |   <style> | ||||||
|  |     .header { | ||||||
|  |       text-decoration: underline; | ||||||
|  |       text-align: center; | ||||||
|  |     } | ||||||
|  |     .node-showcase { | ||||||
|  |       display: grid; | ||||||
|  |       grid-template-columns: 1fr 1fr; | ||||||
|  |     } | ||||||
|  |     .test { | ||||||
|  |       flex-grow: 1; | ||||||
|  |       display: flex; | ||||||
|  |       flex-direction: column; | ||||||
|  |       align-items: center; | ||||||
|  |       gap: 0.4rem; | ||||||
|  |     } | ||||||
|  |     .test > h2 { | ||||||
|  |       margin: 0; | ||||||
|  |       text-align: center; | ||||||
|  |     } | ||||||
|  |     .test > p { | ||||||
|  |       margin-top: -6px; | ||||||
|  |       color: gray; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     .diagram-showcase { | ||||||
|  |       display: grid; | ||||||
|  |       grid-template-columns: 1fr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     .styleClass > * > path { | ||||||
|  |       fill: #ff0000 !important; | ||||||
|  |       stroke: #ffff00 !important; | ||||||
|  |       stroke-width: 4px !important; | ||||||
|  |       stroke-dasharray: 2 !important; | ||||||
|  |     } | ||||||
|  |   </style> | ||||||
|  | </html> | ||||||
							
								
								
									
										152
									
								
								cypress/timings.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										152
									
								
								cypress/timings.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,152 @@ | |||||||
|  | { | ||||||
|  |   "durations": [ | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/other/configuration.spec.js", | ||||||
|  |       "duration": 4989 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/other/external-diagrams.spec.js", | ||||||
|  |       "duration": 1382 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/other/ghsa.spec.js", | ||||||
|  |       "duration": 3178 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/other/iife.spec.js", | ||||||
|  |       "duration": 1372 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/other/interaction.spec.js", | ||||||
|  |       "duration": 8998 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/other/rerender.spec.js", | ||||||
|  |       "duration": 1249 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/other/xss.spec.js", | ||||||
|  |       "duration": 25664 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/appli.spec.js", | ||||||
|  |       "duration": 1928 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/architecture.spec.ts", | ||||||
|  |       "duration": 2330 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/block.spec.js", | ||||||
|  |       "duration": 11156 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/c4.spec.js", | ||||||
|  |       "duration": 3418 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/classDiagram-v2.spec.js", | ||||||
|  |       "duration": 14866 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/classDiagram.spec.js", | ||||||
|  |       "duration": 9894 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/conf-and-directives.spec.js", | ||||||
|  |       "duration": 5778 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/current.spec.js", | ||||||
|  |       "duration": 1690 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/erDiagram.spec.js", | ||||||
|  |       "duration": 9144 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/errorDiagram.spec.js", | ||||||
|  |       "duration": 1951 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/flowchart-elk.spec.js", | ||||||
|  |       "duration": 2196 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/flowchart-handDrawn.spec.js", | ||||||
|  |       "duration": 21029 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/flowchart-shape-alias.spec.ts", | ||||||
|  |       "duration": 16087 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/flowchart-v2.spec.js", | ||||||
|  |       "duration": 27465 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/flowchart.spec.js", | ||||||
|  |       "duration": 20035 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/gantt.spec.js", | ||||||
|  |       "duration": 11366 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/gitGraph.spec.js", | ||||||
|  |       "duration": 34025 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/iconShape.spec.ts", | ||||||
|  |       "duration": 185902 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/imageShape.spec.ts", | ||||||
|  |       "duration": 41631 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/info.spec.ts", | ||||||
|  |       "duration": 1736 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/journey.spec.js", | ||||||
|  |       "duration": 2247 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/katex.spec.js", | ||||||
|  |       "duration": 2144 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/marker_unique_id.spec.js", | ||||||
|  |       "duration": 1646 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/mindmap.spec.ts", | ||||||
|  |       "duration": 6406 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/newShapes.spec.ts", | ||||||
|  |       "duration": 107219 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/stateDiagram.spec.js", | ||||||
|  |       "duration": 15834 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/theme.spec.js", | ||||||
|  |       "duration": 33240 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/timeline.spec.ts", | ||||||
|  |       "duration": 7122 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/xyChart.spec.js", | ||||||
|  |       "duration": 11127 | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "spec": "cypress/integration/rendering/zenuml.spec.js", | ||||||
|  |       "duration": 2391 | ||||||
|  |     } | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										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~~ |       class People List~List~Person~~ | ||||||
|     </pre> |     </pre> | ||||||
|     <hr /> |     <hr /> | ||||||
|  |  | ||||||
|     <pre class="mermaid"> |     <pre class="mermaid"> | ||||||
|     classDiagram |     classDiagram | ||||||
|       A1 --> B1 |       namespace Company.Project.Module { | ||||||
|       namespace A { |         class GenericClass~T~ { | ||||||
|         class A1 { |           +addItem(item: T) | ||||||
|           +foo : string |           +getItem() T | ||||||
|         } |  | ||||||
|         class A2 { |  | ||||||
|           +bar : int |  | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|       namespace B { |  | ||||||
|         class B1 { |  | ||||||
|           +foo : bool |  | ||||||
|         } |  | ||||||
|         class B2 { |  | ||||||
|           +bar : float |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|       A2 --> B2 |  | ||||||
|     </pre> |     </pre> | ||||||
|     <hr /> |     <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"> |     <script type="module"> | ||||||
|       import mermaid from './mermaid.esm.mjs'; |       import mermaid from './mermaid.esm.mjs'; | ||||||
|       mermaid.initialize({ |       mermaid.initialize({ | ||||||
|   | |||||||
| @@ -39,8 +39,8 @@ graph TB | |||||||
|  |  | ||||||
|     <script type="module"> |     <script type="module"> | ||||||
|       import mermaid from '/mermaid.esm.mjs'; |       import mermaid from '/mermaid.esm.mjs'; | ||||||
|       import flowchartELK from '/mermaid-flowchart-elk.esm.mjs'; |       import layouts from '/mermaid-layout-elk.esm.mjs'; | ||||||
|       await mermaid.registerExternalDiagrams([flowchartELK]); |       mermaid.registerLayoutLoaders(layouts); | ||||||
|       async function render(str) { |       async function render(str) { | ||||||
|         const { svg } = await mermaid.render('dynamic', str); |         const { svg } = await mermaid.render('dynamic', str); | ||||||
|         document.getElementById('dynamicDiagram').innerHTML = svg; |         document.getElementById('dynamicDiagram').innerHTML = svg; | ||||||
|   | |||||||
| @@ -125,6 +125,35 @@ | |||||||
|     </pre> |     </pre> | ||||||
|     <hr /> |     <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"> |     <pre class="mermaid"> | ||||||
|     erDiagram |     erDiagram | ||||||
|       _customer_order { |       _customer_order { | ||||||
|   | |||||||
| @@ -88,6 +88,9 @@ | |||||||
|       <li> |       <li> | ||||||
|         <h2><a href="./block.html">Layered Blocks</a></h2> |         <h2><a href="./block.html">Layered Blocks</a></h2> | ||||||
|       </li> |       </li> | ||||||
|  |       <li> | ||||||
|  |         <h2><a href="./architecture.html">Architecture</a></h2> | ||||||
|  |       </li> | ||||||
|     </ul> |     </ul> | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -7,9 +7,6 @@ services: | |||||||
|     tty: true |     tty: true | ||||||
|     working_dir: /mermaid |     working_dir: /mermaid | ||||||
|     mem_limit: '8G' |     mem_limit: '8G' | ||||||
|     entrypoint: ./docker-entrypoint.sh |  | ||||||
|     environment: |  | ||||||
|       - NODE_OPTIONS=--max_old_space_size=8192 |  | ||||||
|     volumes: |     volumes: | ||||||
|       - ./:/mermaid |       - ./:/mermaid | ||||||
|       - root_cache:/root/.cache |       - root_cache:/root/.cache | ||||||
|   | |||||||
| @@ -1,3 +0,0 @@ | |||||||
| #!/bin/sh |  | ||||||
| source /root/.shrc |  | ||||||
| exec "$@" |  | ||||||
							
								
								
									
										233
									
								
								docs/adding-new-shape.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										233
									
								
								docs/adding-new-shape.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,233 @@ | |||||||
|  | > **Warning** | ||||||
|  | > | ||||||
|  | > ## THIS IS AN AUTOGENERATED FILE. DO NOT EDIT. | ||||||
|  | > | ||||||
|  | > ## Please edit the corresponding file in [/packages/mermaid/src/docs/adding-new-shape.md](../packages/mermaid/src/docs/adding-new-shape.md). | ||||||
|  |  | ||||||
|  | # Custom SVG Shapes Library | ||||||
|  |  | ||||||
|  | This library provides a collection of custom SVG shapes, utilities, and helpers for generating diagram components. The shapes are designed to be used within an SVG container and include a variety of common and complex shapes. | ||||||
|  |  | ||||||
|  | ## Overview | ||||||
|  |  | ||||||
|  | ## Shape Helpers and Utilities | ||||||
|  |  | ||||||
|  | Before starting with shape creation, it's essential to familiarize yourself with the utilities provided in the `utils.ts` file from `packages/mermaid/src/rendering-util/rendering-elements/shapes/util.js`. These utilities are designed to assist with various aspects of SVG shape manipulation and ensure consistent and accurate rendering. | ||||||
|  |  | ||||||
|  | ## Available Utilities | ||||||
|  |  | ||||||
|  | ### 1. `labelHelper` | ||||||
|  |  | ||||||
|  | - **Purpose**: This function creates and inserts labels inside SVG shapes. | ||||||
|  | - **Features**: | ||||||
|  |   - Handles both HTML labels and plain text. | ||||||
|  |   - Calculates the bounding box dimensions of the label. | ||||||
|  |   - Ensures proper positioning of labels within shapes. | ||||||
|  |  | ||||||
|  | ### 2. `updateNodeBounds` | ||||||
|  |  | ||||||
|  | - **Purpose**: Updates the bounding box dimensions (width and height) of a node. | ||||||
|  | - **Usage**: | ||||||
|  |   - Adjusts the size of the node to fit the content or shape. | ||||||
|  |   - Useful for ensuring that shapes resize appropriately based on their content. | ||||||
|  |  | ||||||
|  | ### 3. `insertPolygonShape` | ||||||
|  |  | ||||||
|  | - **Purpose**: Inserts a polygon shape into an SVG container. | ||||||
|  | - **Features**: | ||||||
|  |   - Handles the creation and insertion of complex polygonal shapes. | ||||||
|  |   - Configures the shape's appearance and positioning within the SVG container. | ||||||
|  |  | ||||||
|  | ### 4. `getNodeClasses` | ||||||
|  |  | ||||||
|  | - **Purpose**: Returns the appropriate CSS classes for a node based on its configuration. | ||||||
|  | - **Usage**: | ||||||
|  |   - Dynamically applies CSS classes to nodes for styling purposes. | ||||||
|  |   - Ensures that nodes adhere to the desired design and theme. | ||||||
|  |  | ||||||
|  | ### 5. `createPathFromPoints` | ||||||
|  |  | ||||||
|  | - **Purpose**: Generates an SVG path string from an array of points. | ||||||
|  | - **Usage**: | ||||||
|  |   - Converts a list of points into a smooth path. | ||||||
|  |   - Useful for creating custom shapes or paths within the SVG. | ||||||
|  |  | ||||||
|  | ### 6. `generateFullSineWavePoints` | ||||||
|  |  | ||||||
|  | - **Purpose**: Generates points for a sine wave, useful for creating wavy-edged shapes. | ||||||
|  | - **Usage**: | ||||||
|  |   - Facilitates the creation of shapes with wavy or sine-wave edges. | ||||||
|  |   - Can be used to add decorative or dynamic edges to shapes. | ||||||
|  |  | ||||||
|  | ## Getting Started | ||||||
|  |  | ||||||
|  | To utilize these utilities, simply import them from the `utils.ts` file into your shape creation script. These helpers will streamline the process of building and customizing SVG shapes, ensuring consistent results across your projects. | ||||||
|  |  | ||||||
|  | ```typescript | ||||||
|  | import { | ||||||
|  |   labelHelper, | ||||||
|  |   updateNodeBounds, | ||||||
|  |   insertPolygonShape, | ||||||
|  |   getNodeClasses, | ||||||
|  |   createPathFromPoints, | ||||||
|  |   generateFullSineWavePoints, | ||||||
|  | } from './utils.ts'; | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Example Usage | ||||||
|  |  | ||||||
|  | Here’s a basic example of how you might use some of these utilities: | ||||||
|  |  | ||||||
|  | ```typescript | ||||||
|  | import { labelHelper, insertPolygonShape } from './utils.ts'; | ||||||
|  |  | ||||||
|  | const svgContainer = document.getElementById('svgContainer'); | ||||||
|  |  | ||||||
|  | // Insert a polygon shape | ||||||
|  | insertPolygonShape(svgContainer /* shape-specific parameters */); | ||||||
|  |  | ||||||
|  | // Create and insert a label inside the shape | ||||||
|  | labelHelper(svgContainer /* label-specific parameters */); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Adding New Shapes | ||||||
|  |  | ||||||
|  | ### 1. Create the Shape Function | ||||||
|  |  | ||||||
|  | To add a new shape: | ||||||
|  |  | ||||||
|  | - **Create the shape function**: Create a new file of name of the shape and export a function in the `shapes` directory that generates your shape. The file and function should follow the pattern used in existing shapes and return an SVG element. | ||||||
|  |  | ||||||
|  | - **Example**: | ||||||
|  |  | ||||||
|  |   ```typescript | ||||||
|  |   import { Node, RenderOptions } from '../../types.ts'; | ||||||
|  |  | ||||||
|  |   export const myNewShape = async ( | ||||||
|  |     parent: SVGAElement, | ||||||
|  |     node: Node, | ||||||
|  |     renderOptions: RenderOptions | ||||||
|  |   ) => { | ||||||
|  |     // Create your shape here | ||||||
|  |     const shape = parent.insert('g').attr('class', 'my-new-shape'); | ||||||
|  |     // Add other elements or styles as needed | ||||||
|  |     return shape; | ||||||
|  |   }; | ||||||
|  |   ``` | ||||||
|  |  | ||||||
|  | ### 2. Register the Shape | ||||||
|  |  | ||||||
|  | - **Register the shape**: Add your shape to the `shapes` object in the [main shapes module](../rendering-util/rendering-elements/shapes.ts). This allows your shape to be recognized and used within the system. | ||||||
|  |  | ||||||
|  | - **Example**: | ||||||
|  |  | ||||||
|  |   ```typescript | ||||||
|  |   import { myNewShape } from './shapes/myNewShape'; | ||||||
|  |  | ||||||
|  |   const shapes = { | ||||||
|  |     ..., | ||||||
|  |     { | ||||||
|  |       semanticName: 'My Shape', | ||||||
|  |       name: 'Shape Name', | ||||||
|  |       shortName: '<short-name>', | ||||||
|  |       description: '<Description for the shape>', | ||||||
|  |       aliases: ['<alias-one>', '<al-on>', '<alias-two>', '<al-two>'], | ||||||
|  |       handler: myNewShape, | ||||||
|  |     }, | ||||||
|  |   }; | ||||||
|  |   ``` | ||||||
|  |  | ||||||
|  | # Shape Intersection Algorithms | ||||||
|  |  | ||||||
|  | This contains algorithms and utilities for calculating intersection points for various shapes in SVG. Arrow intersection points are crucial for accurately determining where arrows connect with shapes. Ensuring precise intersection points enhances the clarity and accuracy of flowcharts and diagrams. | ||||||
|  |  | ||||||
|  | ## Shape Intersection Functions | ||||||
|  |  | ||||||
|  | ### 1. `Ellipse` | ||||||
|  |  | ||||||
|  | Calculates the intersection points for an ellipse. | ||||||
|  |  | ||||||
|  | **Usage**: | ||||||
|  |  | ||||||
|  | ```javascript | ||||||
|  | import intersectEllipse from './intersect-ellipse.js'; | ||||||
|  |  | ||||||
|  | const intersection = intersectEllipse(node, rx, ry, point); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | - **Parameters**: | ||||||
|  |   - `node`: The SVG node element. | ||||||
|  |   - `rx`: The x-radius of the ellipse. | ||||||
|  |   - `ry`: The y-radius of the ellipse. | ||||||
|  |   - `point`: The point from which the intersection is calculated. | ||||||
|  |  | ||||||
|  | ### 2. `intersectRect` | ||||||
|  |  | ||||||
|  | Calculates the intersection points for a rectangle. | ||||||
|  |  | ||||||
|  | **Usage**: | ||||||
|  |  | ||||||
|  | ```javascript | ||||||
|  | import intersectRect from './intersect-rect.js'; | ||||||
|  |  | ||||||
|  | const intersection = intersectRect(node, point); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | - **Parameters**: | ||||||
|  |   - `node`: The SVG node element. | ||||||
|  |   - `point`: The point from which the intersection is calculated. | ||||||
|  |  | ||||||
|  | ### 3. `intersectPolygon` | ||||||
|  |  | ||||||
|  | Calculates the intersection points for a polygon. | ||||||
|  |  | ||||||
|  | **Usage**: | ||||||
|  |  | ||||||
|  | ```javascript | ||||||
|  | import intersectPolygon from './intersect-polygon.js'; | ||||||
|  |  | ||||||
|  | const intersection = intersectPolygon(node, polyPoints, point); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | - **Parameters**: | ||||||
|  |   - `node`: The SVG node element. | ||||||
|  |   - `polyPoints`: Array of points defining the polygon. | ||||||
|  |   - `point`: The point from which the intersection is calculated. | ||||||
|  |  | ||||||
|  | ## Cypress Tests | ||||||
|  |  | ||||||
|  | To ensure the robustness of the flowchart shapes, there are implementation of comprehensive Cypress test cases in `newShapes.spec.ts` file. These tests cover various aspects such as: | ||||||
|  |  | ||||||
|  | - **Shapes**: Testing new shapes like `bowTieRect`, `waveRectangle`, `trapezoidalPentagon`, etc. | ||||||
|  | - **Looks**: Verifying shapes under different visual styles (`classic` and `handDrawn`). | ||||||
|  | - **Directions**: Ensuring correct rendering in all flow directions of arrows : | ||||||
|  |   - `TB` `(Top -> Bottom)` | ||||||
|  |   - `BT` `(Bottom -> Top)` | ||||||
|  |   - `LR` `(Left -> Right)` | ||||||
|  |   - `RL` `(Right -> Left)` | ||||||
|  | - **Labels**: Testing shapes with different labels, including: | ||||||
|  |   - No labels | ||||||
|  |   - Short labels | ||||||
|  |   - Very long labels | ||||||
|  |   - Markdown with `htmlLabels:true` and `htmlLabels:false` | ||||||
|  | - **Styles**: Applying custom styles to shapes and verifying correct rendering. | ||||||
|  | - **Class Definitions**: Using `classDef` to apply custom classes and testing their impact. | ||||||
|  |  | ||||||
|  | ### Running the Tests | ||||||
|  |  | ||||||
|  | To run the Cypress tests, follow these steps: | ||||||
|  |  | ||||||
|  | 1. Ensure you have all dependencies installed by running: | ||||||
|  |  | ||||||
|  |    ```bash | ||||||
|  |    pnpm install | ||||||
|  |    ``` | ||||||
|  |  | ||||||
|  | 2. Start the Cypress test runner: | ||||||
|  |  | ||||||
|  |    ```bash | ||||||
|  |    cypress open --env updateSnapshots=true | ||||||
|  |  | ||||||
|  |    ``` | ||||||
|  |  | ||||||
|  | 3. Select the test suite from the Cypress interface to run all the flowchart shape tests. | ||||||
| @@ -370,9 +370,9 @@ If the users have no way to know that things have changed, then you haven't real | |||||||
| Likewise, if users don't know that there is a new feature that you've implemented, it will forever remain unknown and unused. | Likewise, if users don't know that there is a new feature that you've implemented, it will forever remain unknown and unused. | ||||||
|  |  | ||||||
| The documentation has to be updated for users to know that things have been changed and added! | The documentation has to be updated for users to know that things have been changed and added! | ||||||
| If you are adding a new feature, add `(v10.8.0+)` in the title or description. It will be replaced automatically with the current version number when the release happens. | If you are adding a new feature, add `(v<MERMAID_RELEASE_VERSION>+)` in the title or description. It will be replaced automatically with the current version number when the release happens. | ||||||
|  |  | ||||||
| eg: `# Feature Name (v10.8.0+)` | eg: `# Feature Name (v<MERMAID_RELEASE_VERSION>+)` | ||||||
|  |  | ||||||
| We know it can sometimes be hard to code _and_ write user documentation. | We know it can sometimes be hard to code _and_ write user documentation. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -6,12 +6,12 @@ | |||||||
|  |  | ||||||
| # Frequently Asked Questions | # Frequently Asked Questions | ||||||
|  |  | ||||||
| 1. [How to add title to flowchart?](https://github.com/knsv/mermaid/issues/556#issuecomment-363182217) | 1. [How to add title to flowchart?](https://github.com/mermaid-js/mermaid/issues/556#issuecomment-363182217) | ||||||
| 2. [How to specify custom CSS file?](https://github.com/mermaidjs/mermaid.cli/pull/24#issuecomment-373402785) | 2. [How to specify custom CSS file?](https://github.com/mermaidjs/mermaid.cli/pull/24#issuecomment-373402785) | ||||||
| 3. [How to fix tooltip misplacement issue?](https://github.com/knsv/mermaid/issues/542#issuecomment-3343564621) | 3. [How to fix tooltip misplacement issue?](https://github.com/mermaid-js/mermaid/issues/542#issuecomment-3343564621) | ||||||
| 4. [How to specify gantt diagram xAxis format?](https://github.com/knsv/mermaid/issues/269#issuecomment-373229136) | 4. [How to specify gantt diagram xAxis format?](https://github.com/mermaid-js/mermaid/issues/269#issuecomment-373229136) | ||||||
| 5. [How to bind an event?](https://github.com/knsv/mermaid/issues/372) | 5. [How to bind an event?](https://github.com/mermaid-js/mermaid/issues/372) | ||||||
| 6. [How to add newline in the text?](https://github.com/knsv/mermaid/issues/384#issuecomment-281339381) | 6. [How to add newline in the text?](https://github.com/mermaid-js/mermaid/issues/384#issuecomment-281339381) | ||||||
| 7. [How to have special characters in link text?](https://github.com/knsv/mermaid/issues/407#issuecomment-329944735) | 7. [How to have special characters in link text?](https://github.com/mermaid-js/mermaid/issues/407#issuecomment-329944735) | ||||||
| 8. [How to change Flowchart curve style?](https://github.com/knsv/mermaid/issues/580#issuecomment-373929046) | 8. [How to change Flowchart curve style?](https://github.com/mermaid-js/mermaid/issues/580#issuecomment-373929046) | ||||||
| 9. [How to create a Flowchart end-Node that says "End"](https://github.com/mermaid-js/mermaid/issues/1444#issuecomment-639528897) | 9. [How to create a Flowchart end-Node that says "End"](https://github.com/mermaid-js/mermaid/issues/1444#issuecomment-639528897) | ||||||
|   | |||||||
							
								
								
									
										55
									
								
								docs/config/icons.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								docs/config/icons.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | > **Warning** | ||||||
|  | > | ||||||
|  | > ## THIS IS AN AUTOGENERATED FILE. DO NOT EDIT. | ||||||
|  | > | ||||||
|  | > ## Please edit the corresponding file in [/packages/mermaid/src/docs/config/icons.md](../../packages/mermaid/src/docs/config/icons.md). | ||||||
|  |  | ||||||
|  | # Registering icon pack in mermaid | ||||||
|  |  | ||||||
|  | The icon packs available can be found at [icones.js.org](https://icones.js.org/). | ||||||
|  | We use the name defined when registering the icon pack, to override the prefix field of the iconify pack. This allows the user to use shorter names for the icons. It also allows us to load a particular pack only when it is used in a diagram. | ||||||
|  |  | ||||||
|  | Using JSON file directly from CDN: | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | import mermaid from 'CDN/mermaid.esm.mjs'; | ||||||
|  | mermaid.registerIconPacks([ | ||||||
|  |   { | ||||||
|  |     name: 'logos', | ||||||
|  |     loader: () => | ||||||
|  |       fetch('https://unpkg.com/@iconify-json/logos@1/icons.json').then((res) => res.json()), | ||||||
|  |   }, | ||||||
|  | ]); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Using packages and a bundler: | ||||||
|  |  | ||||||
|  | ```bash | ||||||
|  | npm install @iconify-json/logos@1 | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | With lazy loading | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | import mermaid from 'mermaid'; | ||||||
|  |  | ||||||
|  | mermaid.registerIconPacks([ | ||||||
|  |   { | ||||||
|  |     name: 'logos', | ||||||
|  |     loader: () => import('@iconify-json/logos').then((module) => module.icons), | ||||||
|  |   }, | ||||||
|  | ]); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Without lazy loading | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | import mermaid from 'mermaid'; | ||||||
|  | import { icons } from '@iconify-json/logos'; | ||||||
|  | mermaid.registerIconPacks([ | ||||||
|  |   { | ||||||
|  |     name: icons.prefix, // To use the prefix defined in the icon pack | ||||||
|  |     icons, | ||||||
|  |   }, | ||||||
|  | ]); | ||||||
|  | ``` | ||||||
| @@ -127,7 +127,7 @@ Error.prepareStackTrace | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| node_modules/@types/node/globals.d.ts:28 | node_modules/.pnpm/@types+node\@20.16.11/node_modules/@types/node/globals.d.ts:98 | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -141,7 +141,7 @@ Error.stackTraceLimit | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| node_modules/@types/node/globals.d.ts:30 | node_modules/.pnpm/@types+node\@20.16.11/node_modules/@types/node/globals.d.ts:100 | ||||||
|  |  | ||||||
| ## Methods | ## Methods | ||||||
|  |  | ||||||
| @@ -168,4 +168,4 @@ Error.captureStackTrace | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| node_modules/@types/node/globals.d.ts:21 | node_modules/.pnpm/@types+node\@20.16.11/node_modules/@types/node/globals.d.ts:91 | ||||||
|   | |||||||
| @@ -16,11 +16,11 @@ | |||||||
|  |  | ||||||
| ### config | ### config | ||||||
|  |  | ||||||
| • **config**: `MermaidConfig` | • **config**: [`MermaidConfig`](mermaid.MermaidConfig.md) | ||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/rendering-util/types.d.ts:118](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/rendering-util/types.d.ts#L118) | [packages/mermaid/src/rendering-util/types.ts:148](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/rendering-util/types.ts#L148) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -30,7 +30,7 @@ | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/rendering-util/types.d.ts:117](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/rendering-util/types.d.ts#L117) | [packages/mermaid/src/rendering-util/types.ts:147](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/rendering-util/types.ts#L147) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -40,4 +40,4 @@ | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/rendering-util/types.d.ts:116](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/rendering-util/types.d.ts#L116) | [packages/mermaid/src/rendering-util/types.ts:146](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/rendering-util/types.ts#L146) | ||||||
|   | |||||||
| @@ -28,7 +28,7 @@ page. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:435](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L435) | [packages/mermaid/src/mermaid.ts:436](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L436) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -59,7 +59,7 @@ A graph definition key | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:437](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L437) | [packages/mermaid/src/mermaid.ts:438](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L438) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -89,7 +89,7 @@ Use [initialize](mermaid.Mermaid.md#initialize) and [run](mermaid.Mermaid.md#run | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:430](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L430) | [packages/mermaid/src/mermaid.ts:431](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L431) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -116,7 +116,7 @@ This function should be called before the run function. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:434](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L434) | [packages/mermaid/src/mermaid.ts:435](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L435) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -130,7 +130,7 @@ Use [parse](mermaid.Mermaid.md#parse) and [render](mermaid.Mermaid.md#render) in | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:424](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L424) | [packages/mermaid/src/mermaid.ts:425](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L425) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -180,7 +180,7 @@ Error if the diagram is invalid and parseOptions.suppressErrors is false or not | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:425](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L425) | [packages/mermaid/src/mermaid.ts:426](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L426) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -190,7 +190,7 @@ Error if the diagram is invalid and parseOptions.suppressErrors is false or not | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:419](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L419) | [packages/mermaid/src/mermaid.ts:420](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L420) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -218,7 +218,31 @@ Used to register external diagram types. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:433](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L433) | [packages/mermaid/src/mermaid.ts:434](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L434) | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | ### registerIconPacks | ||||||
|  |  | ||||||
|  | • **registerIconPacks**: (`iconLoaders`: `IconLoader`\[]) => `void` | ||||||
|  |  | ||||||
|  | #### Type declaration | ||||||
|  |  | ||||||
|  | ▸ (`iconLoaders`): `void` | ||||||
|  |  | ||||||
|  | ##### Parameters | ||||||
|  |  | ||||||
|  | | Name          | Type            | | ||||||
|  | | :------------ | :-------------- | | ||||||
|  | | `iconLoaders` | `IconLoader`\[] | | ||||||
|  |  | ||||||
|  | ##### Returns | ||||||
|  |  | ||||||
|  | `void` | ||||||
|  |  | ||||||
|  | #### Defined in | ||||||
|  |  | ||||||
|  | [packages/mermaid/src/mermaid.ts:439](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L439) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -242,7 +266,7 @@ Used to register external diagram types. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:432](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L432) | [packages/mermaid/src/mermaid.ts:433](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L433) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -268,7 +292,7 @@ Used to register external diagram types. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:426](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L426) | [packages/mermaid/src/mermaid.ts:427](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L427) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -316,7 +340,7 @@ Renders the mermaid diagrams | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:431](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L431) | [packages/mermaid/src/mermaid.ts:432](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L432) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -351,7 +375,7 @@ to it (eg. dart interop wrapper). (Initially there is no parseError member of me | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:436](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L436) | [packages/mermaid/src/mermaid.ts:437](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L437) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -361,4 +385,4 @@ to it (eg. dart interop wrapper). (Initially there is no parseError member of me | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:418](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L418) | [packages/mermaid/src/mermaid.ts:419](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L419) | ||||||
|   | |||||||
| @@ -16,7 +16,17 @@ | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:112](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L112) | [packages/mermaid/src/config.type.ts:122](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L122) | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | ### architecture | ||||||
|  |  | ||||||
|  | • `Optional` **architecture**: `ArchitectureDiagramConfig` | ||||||
|  |  | ||||||
|  | #### Defined in | ||||||
|  |  | ||||||
|  | [packages/mermaid/src/config.type.ts:194](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L194) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -29,7 +39,7 @@ This matters if you are using base tag settings. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:131](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L131) | [packages/mermaid/src/config.type.ts:141](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L141) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -39,7 +49,7 @@ This matters if you are using base tag settings. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:189](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L189) | [packages/mermaid/src/config.type.ts:201](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L201) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -49,7 +59,7 @@ This matters if you are using base tag settings. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:186](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L186) | [packages/mermaid/src/config.type.ts:198](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L198) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -59,7 +69,7 @@ This matters if you are using base tag settings. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:177](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L177) | [packages/mermaid/src/config.type.ts:187](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L187) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -69,7 +79,7 @@ This matters if you are using base tag settings. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:103](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L103) | [packages/mermaid/src/config.type.ts:113](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L113) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -83,7 +93,7 @@ You can set this attribute to base the seed on a static string. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:171](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L171) | [packages/mermaid/src/config.type.ts:181](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L181) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -101,7 +111,7 @@ should not change unless content is changed. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:164](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L164) | [packages/mermaid/src/config.type.ts:174](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L174) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -111,7 +121,7 @@ should not change unless content is changed. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:190](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L190) | [packages/mermaid/src/config.type.ts:202](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L202) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -122,7 +132,8 @@ should not change unless content is changed. | |||||||
| #### Type declaration | #### Type declaration | ||||||
|  |  | ||||||
| | Name                     | Type                                                                                          | Description                                                                                                                                               | | | Name                     | Type                                                                                          | Description                                                                                                                                               | | ||||||
| | :----------------------- | :---------------------------------------------------------------------------- | :-------------------------------------------------------------------------------------------------------------------------------------------------------- | | | :----------------------- | :-------------------------------------------------------------------------------------------- | :-------------------------------------------------------------------------------------------------------------------------------------------------------- | | ||||||
|  | | `cycleBreakingStrategy?` | `"GREEDY"` \| `"DEPTH_FIRST"` \| `"INTERACTIVE"` \| `"MODEL_ORDER"` \| `"GREEDY_MODEL_ORDER"` | This strategy decides how to find cycles in the graph and deciding which edges need adjustment to break loops.                                            | | ||||||
| | `mergeEdges?`            | `boolean`                                                                                     | Elk specific option that allows edges to share path where it convenient. It can make for pretty diagrams but can also make it harder to read the diagram. | | | `mergeEdges?`            | `boolean`                                                                                     | Elk specific option that allows edges to share path where it convenient. It can make for pretty diagrams but can also make it harder to read the diagram. | | ||||||
| | `nodePlacementStrategy?` | `"SIMPLE"` \| `"NETWORK_SIMPLEX"` \| `"LINEAR_SEGMENTS"` \| `"BRANDES_KOEPF"`                 | Elk specific option affecting how nodes are placed.                                                                                                       | | | `nodePlacementStrategy?` | `"SIMPLE"` \| `"NETWORK_SIMPLEX"` \| `"LINEAR_SEGMENTS"` \| `"BRANDES_KOEPF"`                 | Elk specific option affecting how nodes are placed.                                                                                                       | | ||||||
|  |  | ||||||
| @@ -138,7 +149,7 @@ should not change unless content is changed. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:179](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L179) | [packages/mermaid/src/config.type.ts:189](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L189) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -148,7 +159,7 @@ should not change unless content is changed. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:172](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L172) | [packages/mermaid/src/config.type.ts:182](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L182) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -162,7 +173,7 @@ See <https://developer.mozilla.org/en-US/docs/Web/CSS/font-family> | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:111](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L111) | [packages/mermaid/src/config.type.ts:121](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L121) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -172,7 +183,7 @@ See <https://developer.mozilla.org/en-US/docs/Web/CSS/font-family> | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:192](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L192) | [packages/mermaid/src/config.type.ts:204](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L204) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -186,7 +197,7 @@ If set to true, ignores legacyMathML. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:153](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L153) | [packages/mermaid/src/config.type.ts:163](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L163) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -196,7 +207,7 @@ If set to true, ignores legacyMathML. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:174](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L174) | [packages/mermaid/src/config.type.ts:184](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L184) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -206,7 +217,7 @@ If set to true, ignores legacyMathML. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:185](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L185) | [packages/mermaid/src/config.type.ts:197](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L197) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -228,7 +239,7 @@ Defines the seed to be used when using handDrawn look. This is important for the | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:104](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L104) | [packages/mermaid/src/config.type.ts:114](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L114) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -238,7 +249,17 @@ Defines the seed to be used when using handDrawn look. This is important for the | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:175](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L175) | [packages/mermaid/src/config.type.ts:185](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L185) | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | ### kanban | ||||||
|  |  | ||||||
|  | • `Optional` **kanban**: `KanbanDiagramConfig` | ||||||
|  |  | ||||||
|  | #### Defined in | ||||||
|  |  | ||||||
|  | [packages/mermaid/src/config.type.ts:196](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L196) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -265,7 +286,7 @@ fall back to legacy rendering for KaTeX. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:146](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L146) | [packages/mermaid/src/config.type.ts:156](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L156) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -277,7 +298,7 @@ This option decides the amount of logging to be used by mermaid. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:117](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L117) | [packages/mermaid/src/config.type.ts:127](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L127) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -299,7 +320,7 @@ Defines which main look to use for the diagram. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:193](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L193) | [packages/mermaid/src/config.type.ts:205](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L205) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -333,7 +354,7 @@ The maximum allowed size of the users text diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:184](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L184) | [packages/mermaid/src/config.type.ts:195](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L195) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -343,7 +364,7 @@ The maximum allowed size of the users text diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:188](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L188) | [packages/mermaid/src/config.type.ts:200](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L200) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -353,7 +374,7 @@ The maximum allowed size of the users text diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:180](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L180) | [packages/mermaid/src/config.type.ts:190](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L190) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -363,7 +384,7 @@ The maximum allowed size of the users text diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:181](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L181) | [packages/mermaid/src/config.type.ts:191](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L191) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -373,7 +394,7 @@ The maximum allowed size of the users text diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:183](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L183) | [packages/mermaid/src/config.type.ts:193](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L193) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -383,7 +404,7 @@ The maximum allowed size of the users text diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:187](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L187) | [packages/mermaid/src/config.type.ts:199](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L199) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -397,7 +418,7 @@ This prevents malicious graph directives from overriding a site's default securi | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:138](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L138) | [packages/mermaid/src/config.type.ts:148](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L148) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -409,7 +430,7 @@ Level of trust for parsed diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:121](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L121) | [packages/mermaid/src/config.type.ts:131](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L131) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -419,7 +440,7 @@ Level of trust for parsed diagram | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:173](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L173) | [packages/mermaid/src/config.type.ts:183](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L183) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -431,7 +452,7 @@ Dictates whether mermaid starts on Page load | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:125](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L125) | [packages/mermaid/src/config.type.ts:135](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L135) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -441,7 +462,7 @@ Dictates whether mermaid starts on Page load | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:178](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L178) | [packages/mermaid/src/config.type.ts:188](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L188) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -454,7 +475,7 @@ This is useful when you want to control how to handle syntax errors in your appl | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:199](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L199) | [packages/mermaid/src/config.type.ts:211](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L211) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -497,7 +518,7 @@ You may also use `themeCSS` to override this value. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:176](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L176) | [packages/mermaid/src/config.type.ts:186](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L186) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -507,7 +528,7 @@ You may also use `themeCSS` to override this value. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:191](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L191) | [packages/mermaid/src/config.type.ts:203](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L203) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -517,4 +538,4 @@ You may also use `themeCSS` to override this value. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/config.type.ts:182](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L182) | [packages/mermaid/src/config.type.ts:192](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/config.type.ts#L192) | ||||||
|   | |||||||
| @@ -19,4 +19,4 @@ The `parseError` function will not be called. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/types.ts:43](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L43) | [packages/mermaid/src/types.ts:64](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L64) | ||||||
|   | |||||||
| @@ -10,6 +10,18 @@ | |||||||
|  |  | ||||||
| ## Properties | ## Properties | ||||||
|  |  | ||||||
|  | ### config | ||||||
|  |  | ||||||
|  | • **config**: [`MermaidConfig`](mermaid.MermaidConfig.md) | ||||||
|  |  | ||||||
|  | The config passed as YAML frontmatter or directives | ||||||
|  |  | ||||||
|  | #### Defined in | ||||||
|  |  | ||||||
|  | [packages/mermaid/src/types.ts:75](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L75) | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
| ### diagramType | ### diagramType | ||||||
|  |  | ||||||
| • **diagramType**: `string` | • **diagramType**: `string` | ||||||
| @@ -18,4 +30,4 @@ The diagram type, e.g. 'flowchart', 'sequence', etc. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/types.ts:50](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L50) | [packages/mermaid/src/types.ts:71](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L71) | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ bindFunctions?.(div); // To call bindFunctions only if it's present. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/types.ts:73](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L73) | [packages/mermaid/src/types.ts:103](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L103) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -51,7 +51,7 @@ The diagram type, e.g. 'flowchart', 'sequence', etc. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/types.ts:63](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L63) | [packages/mermaid/src/types.ts:93](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L93) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -63,4 +63,4 @@ The svg code for the rendered graph. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/types.ts:59](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L59) | [packages/mermaid/src/types.ts:89](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/types.ts#L89) | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ The nodes to render. If this is set, `querySelector` will be ignored. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:48](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L48) | [packages/mermaid/src/mermaid.ts:49](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L49) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -44,7 +44,7 @@ A callback to call after each diagram is rendered. | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:52](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L52) | [packages/mermaid/src/mermaid.ts:53](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L53) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -56,7 +56,7 @@ The query selector to use when finding elements to render. Default: `".mermaid"` | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:44](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L44) | [packages/mermaid/src/mermaid.ts:45](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L45) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| @@ -68,4 +68,4 @@ If `true`, errors will be logged to the console, but not thrown. Default: `false | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:56](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L56) | [packages/mermaid/src/mermaid.ts:57](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L57) | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/defaultConfig.ts:266](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/defaultConfig.ts#L266) | [packages/mermaid/src/defaultConfig.ts:270](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/defaultConfig.ts#L270) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -87,4 +87,4 @@ | |||||||
|  |  | ||||||
| #### Defined in | #### Defined in | ||||||
|  |  | ||||||
| [packages/mermaid/src/mermaid.ts:440](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L440) | [packages/mermaid/src/mermaid.ts:442](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/mermaid.ts#L442) | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								docs/ecosystem/img/python-mermaid-integration-updated.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/ecosystem/img/python-mermaid-integration-updated.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 256 KiB | 
| @@ -44,6 +44,7 @@ To add an integration to this list, see the [Integrations - create page](./integ | |||||||
| - [Deepdwn](https://billiam.itch.io/deepdwn) ✅ | - [Deepdwn](https://billiam.itch.io/deepdwn) ✅ | ||||||
| - [Doctave](https://www.doctave.com/) ✅ | - [Doctave](https://www.doctave.com/) ✅ | ||||||
|   - [Mermaid in Markdown code blocks](https://docs.doctave.com/components/mermaid) ✅ |   - [Mermaid in Markdown code blocks](https://docs.doctave.com/components/mermaid) ✅ | ||||||
|  | - [Forgejo](https://forgejo.org/) ✅ | ||||||
| - [GitBook](https://gitbook.com) | - [GitBook](https://gitbook.com) | ||||||
|   - [Mermaid Plugin](https://github.com/JozoVilcek/gitbook-plugin-mermaid) |   - [Mermaid Plugin](https://github.com/JozoVilcek/gitbook-plugin-mermaid) | ||||||
|   - [Mermaid plugin for GitBook](https://github.com/wwformat/gitbook-plugin-mermaid-pdf) |   - [Mermaid plugin for GitBook](https://github.com/wwformat/gitbook-plugin-mermaid-pdf) | ||||||
| @@ -64,7 +65,7 @@ To add an integration to this list, see the [Integrations - create page](./integ | |||||||
| - [Mermaid Flow Visual Editor](https://www.mermaidflow.app) ✅ | - [Mermaid Flow Visual Editor](https://www.mermaidflow.app) ✅ | ||||||
| - [Mermerd](https://github.com/KarnerTh/mermerd) | - [Mermerd](https://github.com/KarnerTh/mermerd) | ||||||
| - [Slab](https://slab.com) ✅ | - [Slab](https://slab.com) ✅ | ||||||
| - [Swimm](https://docs.swimm.io/features/diagrams-and-charts/#mermaid--swimm--up-to-date-diagrams-) ✅ | - [Swimm](https://docs.swimm.io/features/diagrams-and-charts) ✅ | ||||||
| - [NotesHub](https://noteshub.app) ✅ | - [NotesHub](https://noteshub.app) ✅ | ||||||
| - [Notion](https://notion.so) ✅ | - [Notion](https://notion.so) ✅ | ||||||
| - [Observable](https://observablehq.com/@observablehq/mermaid) ✅ | - [Observable](https://observablehq.com/@observablehq/mermaid) ✅ | ||||||
| @@ -74,6 +75,7 @@ To add an integration to this list, see the [Integrations - create page](./integ | |||||||
|   - [Markdown for mermaid plugin](https://github.com/jamieh-mongolian/markdown-for-mermaid-plugin) |   - [Markdown for mermaid plugin](https://github.com/jamieh-mongolian/markdown-for-mermaid-plugin) | ||||||
|   - [redmine-mermaid](https://github.com/styz/redmine_mermaid) |   - [redmine-mermaid](https://github.com/styz/redmine_mermaid) | ||||||
| - Visual Studio Code [Polyglot Interactive Notebooks](https://github.com/dotnet/interactive#net-interactive) | - Visual Studio Code [Polyglot Interactive Notebooks](https://github.com/dotnet/interactive#net-interactive) | ||||||
|  | - [Microsoft Loop](https://loop.cloud.microsoft) ✅ | ||||||
|  |  | ||||||
| ### LLM integrations | ### LLM integrations | ||||||
|  |  | ||||||
| @@ -98,8 +100,7 @@ Blogging frameworks and platforms | |||||||
| - [Nextra](https://nextra.site/) | - [Nextra](https://nextra.site/) | ||||||
|   - [Mermaid](https://nextra.site/docs/guide/mermaid) |   - [Mermaid](https://nextra.site/docs/guide/mermaid) | ||||||
| - [WordPress](https://wordpress.org) | - [WordPress](https://wordpress.org) | ||||||
|   - [WordPress Markdown Editor](https://wordpress.org/plugins/wp-githuber-md) |   - [MerPRess](https://wordpress.org/plugins/merpress/) | ||||||
|   - [WP-ReliableMD](https://wordpress.org/plugins/wp-reliablemd/) |  | ||||||
|  |  | ||||||
| ### CMS/ECM | ### CMS/ECM | ||||||
|  |  | ||||||
| @@ -144,7 +145,7 @@ Communication tools and platforms | |||||||
|   - [Mermaid Extension](https://www.mediawiki.org/wiki/Extension:Mermaid) |   - [Mermaid Extension](https://www.mediawiki.org/wiki/Extension:Mermaid) | ||||||
| - [PmWiki](https://www.pmwiki.org) | - [PmWiki](https://www.pmwiki.org) | ||||||
|   - [MermaidJs Cookbook recipe](https://www.pmwiki.org/wiki/Cookbook/MermaidJs) |   - [MermaidJs Cookbook recipe](https://www.pmwiki.org/wiki/Cookbook/MermaidJs) | ||||||
| - [Semantic Media Wiki](https://semantic-mediawiki.org) | - [Semantic Media Wiki](https://www.semantic-mediawiki.org) | ||||||
|   - [Mermaid Plugin](https://github.com/SemanticMediaWiki/Mermaid) |   - [Mermaid Plugin](https://github.com/SemanticMediaWiki/Mermaid) | ||||||
| - [TiddlyWiki](https://tiddlywiki.com/) | - [TiddlyWiki](https://tiddlywiki.com/) | ||||||
|   - [mermaid-tw5: wrapper for Mermaid Live](https://github.com/efurlanm/mermaid-tw5) |   - [mermaid-tw5: wrapper for Mermaid Live](https://github.com/efurlanm/mermaid-tw5) | ||||||
| @@ -184,8 +185,6 @@ Communication tools and platforms | |||||||
|   - [=Diagram block](https://github.com/zag/podlite/tree/main/packages/podlite-diagrams) |   - [=Diagram block](https://github.com/zag/podlite/tree/main/packages/podlite-diagrams) | ||||||
| - [Standard Notes](https://standardnotes.com/) | - [Standard Notes](https://standardnotes.com/) | ||||||
|   - [Mermaid Extension](https://github.com/nienow/sn-mermaid) |   - [Mermaid Extension](https://github.com/nienow/sn-mermaid) | ||||||
| - [Sublime Text 3](https://sublimetext.com) |  | ||||||
|   - [Mermaid Package](https://packagecontrol.io/packages/Mermaid) |  | ||||||
| - [VS Code](https://code.visualstudio.com/) | - [VS Code](https://code.visualstudio.com/) | ||||||
|   - [Mermaid Editor](https://marketplace.visualstudio.com/items?itemName=tomoyukim.vscode-mermaid-editor) |   - [Mermaid Editor](https://marketplace.visualstudio.com/items?itemName=tomoyukim.vscode-mermaid-editor) | ||||||
|   - [Mermaid Export](https://marketplace.visualstudio.com/items?itemName=Gruntfuggly.mermaid-export) |   - [Mermaid Export](https://marketplace.visualstudio.com/items?itemName=Gruntfuggly.mermaid-export) | ||||||
| @@ -199,15 +198,22 @@ Communication tools and platforms | |||||||
| - [Vim](https://www.vim.org) | - [Vim](https://www.vim.org) | ||||||
|   - [Vim Diagram Syntax](https://github.com/zhaozg/vim-diagram) |   - [Vim Diagram Syntax](https://github.com/zhaozg/vim-diagram) | ||||||
|   - [Official Vim Syntax and ft plugin](https://github.com/craigmac/vim-mermaid) |   - [Official Vim Syntax and ft plugin](https://github.com/craigmac/vim-mermaid) | ||||||
|  | - [Zed](https://zed.dev) | ||||||
|  |   - [zed-mermaid](https://github.com/gabeidx/zed-mermaid) | ||||||
|  |  | ||||||
| ### Document Generation | ### Document Generation | ||||||
|  |  | ||||||
|  | - [Astro](https://astro.build/) | ||||||
|  |   - [Adding diagrams to your Astro site with MermaidJS and Playwright](https://agramont.net/blog/diagraming-with-mermaidjs-astro/) | ||||||
| - [Codedoc](https://codedoc.cc/) | - [Codedoc](https://codedoc.cc/) | ||||||
|   - [codedoc-mermaid-plugin](https://www.npmjs.com/package/codedoc-mermaid-plugin) |   - [codedoc-mermaid-plugin](https://www.npmjs.com/package/codedoc-mermaid-plugin) | ||||||
| - [Docsy Hugo Theme](https://www.docsy.dev/docs/adding-content/lookandfeel/#diagrams-with-mermaid) ✅ | - [Docsy Hugo Theme](https://www.docsy.dev/docs/adding-content/lookandfeel/#diagrams-with-mermaid) ✅ | ||||||
| - [Docusaurus](https://docusaurus.io/docs/markdown-features/diagrams) ✅ | - [Docusaurus](https://docusaurus.io/docs/markdown-features/diagrams) ✅ | ||||||
| - [Gatsby](https://www.gatsbyjs.com/) | - [Gatsby](https://www.gatsbyjs.com/) | ||||||
|   - [gatsby-remark-mermaid](https://github.com/remcohaszing/gatsby-remark-mermaid) |   - [gatsby-remark-mermaid](https://github.com/remcohaszing/gatsby-remark-mermaid) | ||||||
|  | - [Jekyll](https://jekyllrb.com/) | ||||||
|  |   - [jekyll-mermaid](https://rubygems.org/gems/jekyll-mermaid) | ||||||
|  |   - [jekyll-mermaid-diagrams](https://github.com/fuzhibo/jekyll-mermaid-diagrams) | ||||||
| - [JSDoc](https://jsdoc.app/) | - [JSDoc](https://jsdoc.app/) | ||||||
|   - [jsdoc-mermaid](https://github.com/Jellyvision/jsdoc-mermaid) |   - [jsdoc-mermaid](https://github.com/Jellyvision/jsdoc-mermaid) | ||||||
| - [Madness](https://madness.dannyb.co/) | - [Madness](https://madness.dannyb.co/) | ||||||
| @@ -216,7 +222,7 @@ Communication tools and platforms | |||||||
| - [MkDocs](https://www.mkdocs.org) | - [MkDocs](https://www.mkdocs.org) | ||||||
|   - [mkdocs-mermaid2-plugin](https://github.com/fralau/mkdocs-mermaid2-plugin) |   - [mkdocs-mermaid2-plugin](https://github.com/fralau/mkdocs-mermaid2-plugin) | ||||||
|   - [mkdocs-material](https://github.com/squidfunk/mkdocs-material), check the [docs](https://squidfunk.github.io/mkdocs-material/reference/diagrams/) |   - [mkdocs-material](https://github.com/squidfunk/mkdocs-material), check the [docs](https://squidfunk.github.io/mkdocs-material/reference/diagrams/) | ||||||
|   - [Quarto](https://quarto.org/) | - [Quarto](https://quarto.org/) ✅ | ||||||
| - [rehype](https://github.com/rehypejs/rehype) | - [rehype](https://github.com/rehypejs/rehype) | ||||||
|   - [rehype-mermaid](https://github.com/remcohaszing/rehype-mermaid) |   - [rehype-mermaid](https://github.com/remcohaszing/rehype-mermaid) | ||||||
| - [remark](https://remark.js.org/) | - [remark](https://remark.js.org/) | ||||||
| @@ -245,17 +251,12 @@ Communication tools and platforms | |||||||
|  |  | ||||||
| ### Other | ### Other | ||||||
|  |  | ||||||
| - [Astro](https://astro.build/) |  | ||||||
|   - [Adding diagrams to your Astro site with MermaidJS and Playwright](https://agramont.net/blog/diagraming-with-mermaidjs-astro/) |  | ||||||
| - [Bisheng](https://www.npmjs.com/package/bisheng) | - [Bisheng](https://www.npmjs.com/package/bisheng) | ||||||
|   - [bisheng-plugin-mermaid](https://github.com/yct21/bisheng-plugin-mermaid) |   - [bisheng-plugin-mermaid](https://github.com/yct21/bisheng-plugin-mermaid) | ||||||
| - [Blazorade Mermaid: Render Mermaid diagrams in Blazor applications](https://github.com/Blazorade/Blazorade-Mermaid/wiki) | - [Blazorade Mermaid: Render Mermaid diagrams in Blazor applications](https://github.com/Blazorade/Blazorade-Mermaid/wiki) | ||||||
| - [Codemia: A tool to practice system design problems](https://codemia.io) ✅ | - [Codemia: A tool to practice system design problems](https://codemia.io) ✅ | ||||||
| - [ExDoc](https://github.com/elixir-lang/ex_doc) | - [ExDoc](https://github.com/elixir-lang/ex_doc) | ||||||
|   - [Rendering Mermaid graphs](https://github.com/elixir-lang/ex_doc#rendering-mermaid-graphs) |   - [Rendering Mermaid graphs](https://github.com/elixir-lang/ex_doc#rendering-mermaid-graphs) | ||||||
| - [Jekyll](https://jekyllrb.com/) |  | ||||||
|   - [jekyll-mermaid](https://rubygems.org/gems/jekyll-mermaid) |  | ||||||
|   - [jekyll-mermaid-diagrams](https://github.com/fuzhibo/jekyll-mermaid-diagrams) |  | ||||||
| - [MarkChart: Preview Mermaid diagrams on macOS](https://markchart.app/) | - [MarkChart: Preview Mermaid diagrams on macOS](https://markchart.app/) | ||||||
| - [mermaid-isomorphic](https://github.com/remcohaszing/mermaid-isomorphic) | - [mermaid-isomorphic](https://github.com/remcohaszing/mermaid-isomorphic) | ||||||
| - [mermaid-server: Generate diagrams using a HTTP request](https://github.com/TomWright/mermaid-server) | - [mermaid-server: Generate diagrams using a HTTP request](https://github.com/TomWright/mermaid-server) | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user