mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-25 17:04:19 +02:00 
			
		
		
		
	Compare commits
	
		
			935 Commits
		
	
	
		
			bug/2234_c
			...
			gh-readonl
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| ![github-merge-queue[bot]](/assets/img/avatar_default.png)  | 96458d8ad1 | ||
|   | 99d3701a85 | ||
|   | 6413529a6e | ||
|   | f5e1df08a0 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 472a883c73 | ||
|   | 22bd26272d | ||
|   | e68125eb6a | ||
|   | 4f1c3547bf | ||
|   | e102ac2b58 | ||
|   | 63dca5bb86 | ||
|   | bc7ecf330b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d4e00de1fd | ||
|   | c4ccfec316 | ||
|   | 1ac9244e68 | ||
|   | 8265e53128 | ||
|   | d316b05fa1 | ||
|   | 3000f0208f | ||
|   | e49c95c220 | ||
|   | 47c5abb8a5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | be9b349e51 | ||
|   | 18defaae6d | ||
|   | 7f33ae0f40 | ||
|   | 13aa3265e3 | ||
|   | 3b0687e557 | ||
|   | 273941a9fe | ||
|   | 718811be9c | ||
|   | 8d9cb09261 | ||
|   | 196d88559c | ||
|   | 3809732e48 | ||
|   | eb4a6fd2ed | ||
|   | 3357844a1f | ||
|   | 0d8fe3b626 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5df988d2ac | ||
|   | e9ef277929 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2dcdcba227 | ||
|   | 5b6c5dff0a | ||
|   | 7fa887b644 | ||
|   | 5c6b2cf490 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e0930b5cbb | ||
|   | 2a3d03254d | ||
|   | e570863801 | ||
|   | 866d9416b4 | ||
|   | e048085b5a | ||
|   | 9ed2f4b2d3 | ||
|   | c2eb2184fc | ||
|   | a2e3b4ca06 | ||
|   | 909ad02a18 | ||
|   | 4a930d2b5b | ||
|   | 4a19103891 | ||
|   | bb0c45b090 | ||
|   | d0583f9947 | ||
|   | 12bd301401 | ||
|   | a14637b416 | ||
|   | 5d1ac22fd1 | ||
|   | 3ccfea84b8 | ||
|   | 38beca11fd | ||
|   | 3555577581 | ||
|   | e852596862 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f15fde26f9 | ||
|   | 73c426f8be | ||
|   | 8f40c1a77f | ||
|   | 0d00e88580 | ||
|   | 8792e0a978 | ||
|   | e27e56f7bf | ||
|   | 0051620840 | ||
|   | 63f9d3e0b4 | ||
|   | 90b1111382 | ||
|   | 0aa526d707 | ||
|   | 4daef2591d | ||
|   | 2d91aa0b06 | ||
|   | 2fd6de0af5 | ||
|   | 799af4e550 | ||
|   | b8e0bcee5b | ||
|   | 3567308a22 | ||
|   | aca0bebaf4 | ||
|   | 4ee4555cbd | ||
|   | 253adcb0eb | ||
|   | 585609b907 | ||
|   | 1d8332d61e | ||
|   | 3f95c78428 | ||
|   | 8e95c4db55 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f476a7566c | ||
|   | 4304fba0f5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 07bd9825a1 | ||
|   | 69c7cb9f6f | ||
|   | fd473af5b0 | ||
|   | d1f02f6bed | ||
|   | c5cc9dbffa | ||
|   | 43e183b658 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 153f319666 | ||
|   | 3b8e6ecc42 | ||
|   | 29ec8cbd0a | ||
|   | 3072604070 | ||
|   | 562d10809c | ||
|   | c00bf26c77 | ||
|   | a2f54f7da4 | ||
|   | 12bf139708 | ||
|   | dbb69ad7cd | ||
|   | b78f16ef19 | ||
|   | 223f339682 | ||
|   | 3f556fa3fc | ||
|   | 16db0c039f | ||
|   | 94874ddbbe | ||
|   | ea86697973 | ||
|   | fa1605e7e7 | ||
|   | 0edef7b3cb | ||
|   | 64757670fc | ||
|   | edac77de74 | ||
|   | 63e3b1af52 | ||
|   | f6fa88e5ff | ||
|   | 78587e11c7 | ||
|   | 784d06f0ae | ||
|   | 6846c8f2ed | ||
|   | cfa4501793 | ||
|   | 16f1dccd22 | ||
|   | 3278899787 | ||
|   | cdbee64086 | ||
|   | 90e134cb26 | ||
|   | 725b618111 | ||
|   | f135a3a5e7 | ||
|   | 8f8e4806a9 | ||
|   | 100123b43e | ||
|   | 45a5424ebf | ||
|   | be37f2c576 | ||
|   | 26ed819664 | ||
|   | f907ac30c6 | ||
|   | 60be7012aa | ||
|   | 002d493035 | ||
|   | a41d6cfef1 | ||
|   | ecfa149efc | ||
|   | be1270d070 | ||
|   | 75ee4b7709 | ||
|   | d5b1028732 | ||
|   | 6c0be03e62 | ||
|   | 7ddea1270f | ||
|   | 97578c2d3d | ||
|   | 64806ed169 | ||
|   | a14c3bcc89 | ||
|   | 1699a23ff0 | ||
|   | 268c3fdbd8 | ||
|   | 7689e03739 | ||
|   | d875540b3a | ||
|   | 16aa9a310c | ||
|   | d0a008566e | ||
|   | d6c1a59bd4 | ||
|   | 07117b4c8a | ||
|   | 46d20c9968 | ||
|   | de1b2c31a1 | ||
|   | 1f9cbe218f | ||
|   | b914f48a91 | ||
|   | de89355a49 | ||
|   | 6502036be9 | ||
|   | f86da19362 | ||
|   | b04e150dc1 | ||
|   | 1c0c374c29 | ||
|   | d370dd43b1 | ||
|   | c90d7b8395 | ||
|   | 4feb2e639b | ||
|   | 37ba7af6f6 | ||
|   | 10fb85663f | ||
|   | 33287a63ad | ||
|   | 3134a87e72 | ||
|   | d68b59a390 | ||
|   | 447263ecc2 | ||
|   | 08a7f662ea | ||
|   | 007fb5deb9 | ||
|   | 6422175ef2 | ||
|   | 32ca0b97fc | ||
|   | 244b161032 | ||
|   | 75a6fb1d91 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 32c2aecc62 | ||
|   | b0ef0de032 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 92692653a7 | ||
|   | 77ba19cd04 | ||
|   | 5b43460ea4 | ||
|   | 579f1f9dc1 | ||
|   | de4ad764ce | ||
|   | 33444466f3 | ||
|   | 73888eafe1 | ||
|   | cd3d560e8d | ||
|   | c0497d3413 | ||
|   | 648f779e2c | ||
|   | b1915132d5 | ||
|   | e6d80c60fb | ||
|   | 05f59f6ed2 | ||
|   | 8f457815e9 | ||
|   | 233944bf24 | ||
|   | 424d988f93 | ||
|   | 3926594c6a | ||
|   | 5f84344c3c | ||
|   | 01082f86b7 | ||
|   | 9fa681f5a8 | ||
|   | 36b6733c4f | ||
|   | 2c195c73a9 | ||
|   | 1dd05ffbb1 | ||
|   | 4884b01b8a | ||
|   | 46136b5632 | ||
|   | ae29dd124c | ||
|   | 703460ea95 | ||
|   | b7c889bb70 | ||
|   | 12bbbcaff0 | ||
|   | b156c1ab25 | ||
|   | 358d855c88 | ||
|   | 1059dd389f | ||
|   | f1bcf89723 | ||
|   | 099a239207 | ||
|   | 821076ba9c | ||
|   | 60dd27671b | ||
|   | 0b0d901b7f | ||
|   | 7fec51f322 | ||
|   | 1659ace65d | ||
|   | 3340608689 | ||
|   | 5ccdb6f213 | ||
|   | 0981b66a5f | ||
|   | 3ddcc2d4ea | ||
|   | 6005479918 | ||
|   | 19e049642b | ||
|   | b8e6672e60 | ||
|   | dbeb0a4720 | ||
|   | da33867ad7 | ||
|   | 539010c65c | ||
|   | cbe44a6cff | ||
|   | b077fedd4c | ||
|   | 5aa884f594 | ||
|   | 5b3f320e5d | ||
|   | a43cd55c53 | ||
|   | 803e068630 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3147bb34ee | ||
|   | 8daa28dd8b | ||
|   | 231534a0db | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2c6d1cb1ce | ||
|   | 972ecba597 | ||
|   | fe905cedd3 | ||
|   | d8b878414b | ||
|   | b3245742b3 | ||
|   | 82fd371e38 | ||
|   | b67dee1eed | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6c1228f039 | ||
|   | be6b3176f4 | ||
|   | 2537bf5310 | ||
|   | f4dffc8cdf | ||
|   | aef29affa3 | ||
|   | 70d236244f | ||
|   | 171a2019ec | ||
|   | 70df6bbbca | ||
|   | 5807d521b7 | ||
|   | 67e482ff97 | ||
|   | 2b2bbe35d0 | ||
|   | 8862d63377 | ||
|   | 2ac4e08e75 | ||
|   | fc7427536c | ||
|   | 1b0b1227b6 | ||
|   | 0cb365cf31 | ||
|   | 49a0d0d9bf | ||
|   | 38fcc2847b | ||
|   | 2caeb9db47 | ||
|   | f9c359e70c | ||
|   | 24528c1426 | ||
|   | 1857eb1dae | ||
|   | 970a98acad | ||
|   | 619f097f1a | ||
|   | 5fe9f9ed57 | ||
|   | 3602191f69 | ||
|   | 5935e277e6 | ||
|   | 0ce33cb160 | ||
|   | df026c795d | ||
|   | d945030803 | ||
|   | 60a484f1e4 | ||
|   | 077b1a5d8a | ||
|   | e59f290546 | ||
|   | 9377d054a0 | ||
|   | 10bb9202a7 | ||
|   | 2c59ceb005 | ||
|   | adf0ae5474 | ||
|   | a9e67e4266 | ||
|   | 0215e0173f | ||
|   | 31a287b7b0 | ||
|   | af93b72ec5 | ||
|   | 370cd98d23 | ||
|   | 31686802b3 | ||
|   | b96eaed6f4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c842401aaa | ||
|   | d163ca7e1b | ||
|   | cbb715a44d | ||
|   | af3d728a72 | ||
|   | 3093afe63e | ||
|   | a5a2ea1c92 | ||
|   | 197d808e33 | ||
|   | 9f8c87a1d8 | ||
|   | 69266bbfe6 | ||
|   | 4707fb27fa | ||
|   | 00bd208f18 | ||
|   | 61c92f9df4 | ||
|   | ed612827d8 | ||
|   | d4ff5f5c27 | ||
|   | a4ba282dc0 | ||
|   | 39d870d069 | ||
|   | 4e12157180 | ||
|   | e371d72e18 | ||
|   | 628cf79048 | ||
|   | ccfec58aeb | ||
|   | a57ac092f0 | ||
|   | 6f3a2605c1 | ||
|   | e79a08ee0f | ||
|   | 77706216c9 | ||
|   | d9448e4a91 | ||
|   | 15b3647514 | ||
|   | 6d58c7504d | ||
|   | c8fc989237 | ||
|   | 392ebd0af4 | ||
|   | 81491f2e34 | ||
|   | 77f76f52b5 | ||
|   | cabcf1e270 | ||
|   | 70c8a3dde8 | ||
|   | 762113d045 | ||
|   | 53599817a9 | ||
|   | 4336b91dbd | ||
|   | eaffe334c4 | ||
|   | 6be91bc3a8 | ||
|   | 551ccfc8ce | ||
|   | e54d0902c1 | ||
|   | 36f056fd92 | ||
|   | c3060548cf | ||
|   | f3282e4dad | ||
|   | 4a7489a7b6 | ||
|   | af7364bdf9 | ||
|   | 23dd7b2b10 | ||
|   | bee88ac70e | ||
|   | 1a8361d5c9 | ||
|   | e21643229e | ||
|   | fe1cff3f55 | ||
|   | 4a4e96cfbd | ||
|   | 14e1e6368a | ||
|   | 447c5a4b35 | ||
|   | 18589ddda4 | ||
|   | 267e142ac9 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9ee2d70c8c | ||
|   | a90a8ceea5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ddd971eae4 | ||
|   | f1aa6fff9c | ||
|   | d11bfaa6c4 | ||
|   | 25cd86feec | ||
|   | 062176d8d0 | ||
|   | a344d88020 | ||
|   | 30b180d77b | ||
|   | 00423ed152 | ||
|   | 48ff3b2c11 | ||
|   | eee0d4bf31 | ||
|   | e047755a21 | ||
|   | b30d609d19 | ||
|   | 1406de5a6c | ||
|   | ec7591bfa8 | ||
|   | c45f39e819 | ||
|   | 6682988403 | ||
|   | 8ad056b8a2 | ||
|   | c1cb171071 | ||
|   | 17959f648a | ||
|   | c3d9aa791a | ||
|   | f846e7719e | ||
|   | f25c215f6a | ||
|   | 2640120be8 | ||
|   | b55014617e | ||
|   | 9c6ad54681 | ||
|   | c7f5e01721 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 19f150922b | ||
|   | be036ad414 | ||
|   | 9261715003 | ||
|   | 42589a0034 | ||
|   | dee99d2c4a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5f0b514c92 | ||
|   | 337f07b865 | ||
|   | b043d79cc4 | ||
|   | 3b5cb020ea | ||
|   | 1c61ccabad | ||
|   | 3fe7e2dfe8 | ||
|   | 51e7444b94 | ||
|   | 2fa9219353 | ||
|   | f5555245f9 | ||
|   | 5c9857c4eb | ||
|   | 494ba45c5e | ||
|   | b38def6866 | ||
|   | a7afc11079 | ||
|   | d3c5b02008 | ||
|   | 16149abcc0 | ||
|   | 13d0b61757 | ||
|   | ebc59d8227 | ||
|   | 45f4d3d443 | ||
|   | 33d45f639c | ||
|   | 7503694453 | ||
|   | e9680e086e | ||
|   | cd7003e9c1 | ||
|   | 941d9d13d5 | ||
|   | 4786cfb6aa | ||
|   | 7aa4466b69 | ||
|   | 2bfd5a9e2a | ||
|   | 56da881ed4 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | a3364e72ff | ||
|   | aa50db8bf5 | ||
|   | e8db7a71e2 | ||
|   | f00e7676b9 | ||
|   | 63ef228ed0 | ||
|   | 6fce617284 | ||
|   | 2a64834ecc | ||
|   | 7bcdea9bd1 | ||
|   | 8fdf512b4c | ||
|   | dbcb80087c | ||
|   | b99b1bfd0c | ||
|   | fcffa6ca4e | ||
|   | 6fd69090ed | ||
|   | 051ef598f6 | ||
|   | 907006ff3d | ||
|   | df9b801b0e | ||
|   | 726d633dd3 | ||
|   | 4a04ce6bf8 | ||
|   | 010fc703eb | ||
|   | 8f8ce2f142 | ||
|   | 452cb83ad7 | ||
|   | 2f8f9dd341 | ||
|   | 4a14d997d1 | ||
|   | 10237976f3 | ||
|   | 92e7c7b894 | ||
|   | 80c20a72b2 | ||
|   | 2d92ffb085 | ||
|   | 4823cf5df4 | ||
|   | dae8a13e8a | ||
|   | 0b087b71dc | ||
|   | ea8d7ec5cc | ||
|   | 78f1631c8f | ||
|   | ff6988e875 | ||
|   | cddca04885 | ||
|   | f737c9f6f9 | ||
|   | 7e86d03dc9 | ||
|   | bfa8111e14 | ||
|   | 5aab2ba1dd | ||
|   | 37d7c7e2dd | ||
|   | 1965f69a10 | ||
|   | 95dcd30324 | ||
|   | 65bb82962f | ||
|   | c84c7f52f9 | ||
|   | cd04c430af | ||
|   | dd553cb28f | ||
|   | 25d0de13a5 | ||
|   | 52bb31b98a | ||
|   | a4a94fd6e2 | ||
|   | cd8e354234 | ||
|   | d797365802 | ||
|   | 73293efcf3 | ||
|   | 91ae282808 | ||
|   | 4c551b2aca | ||
|   | d21461fba0 | ||
|   | b51d8ff7ba | ||
|   | 75ec719257 | ||
|   | 13e052ff81 | ||
|   | bde6a9ff4f | ||
|   | 23d843b6d3 | ||
|   | cffac848ea | ||
|   | 9651d0c2da | ||
|   | e1a23f10df | ||
|   | d346a77e3c | ||
|   | f069de5487 | ||
|   | ba0bddf417 | ||
|   | f30c26485e | ||
|   | b71f4c7e54 | ||
|   | e046da10c2 | ||
|   | 12dc3d8373 | ||
|   | 82c405289d | ||
|   | 191ea24e29 | ||
|   | 72a6fad1db | ||
|   | a2a99485f9 | ||
|   | bc332e3124 | ||
|   | 8d2605d537 | ||
|   | 069a132fe1 | ||
|   | 969e2c1ff1 | ||
|   | c5272d5279 | ||
|   | c1b5d527df | ||
|   | cc4dfeab1a | ||
|   | 280525b4b1 | ||
|   | 9fadf621a8 | ||
|   | fd3f1caff6 | ||
|   | 3b0c5c3e60 | ||
|   | 52d276b010 | ||
|   | d1178c490b | ||
|   | 9ee5667580 | ||
|   | 36c196e80b | ||
|   | 7ca990d762 | ||
|   | 7d0faa3fed | ||
|   | 4256177531 | ||
|   | 327530fb9d | ||
|   | 91907fe0eb | ||
|   | 6bf5571f96 | ||
|   | 8619a53a9c | ||
|   | 9bedfa2033 | ||
|   | 59264a33d7 | ||
|   | 70d9f50fc9 | ||
|   | b253cd65d4 | ||
|   | f2f8d89a28 | ||
|   | 0b0f988180 | ||
|   | 1c200ee5bc | ||
|   | 55be75c974 | ||
|   | 47a6ce4342 | ||
|   | 3ecb841c1a | ||
|   | 1d2450245e | ||
|   | f6c4c9260f | ||
|   | f354d68350 | ||
|   | bea76aa682 | ||
|   | 6d4b27aacb | ||
|   | e008b7dae7 | ||
|   | 96a3991c56 | ||
|   | 8d1d691bc3 | ||
|   | e07608209b | ||
|   | 50cdb74d54 | ||
|   | edc091f4d4 | ||
|   | e0448a7b7b | ||
|   | 0f02f5ff34 | ||
|   | b2111adef5 | ||
|   | 099f580e52 | ||
|   | 442da6c4a2 | ||
|   | f715863540 | ||
|   | ed7dbb100d | ||
|   | 52fdea0419 | ||
|   | 98c578da02 | ||
|   | cbf7e6a880 | ||
|   | 8982e2f78c | ||
|   | 62ae072918 | ||
|   | 04f92e5b1c | ||
|   | b7c72cb38a | ||
|   | 5cc20b5e44 | ||
|   | ce9a9db33a | ||
|   | 6939cf52e6 | ||
|   | ec79ac200c | ||
|   | de03a017db | ||
|   | 42ad1f4fe4 | ||
|   | a01be16d27 | ||
|   | 5c6c8d1135 | ||
|   | 493f238319 | ||
|   | 31e19a0434 | ||
|   | 16968eb38c | ||
|   | 5c46b98eee | ||
|   | ba46747cb0 | ||
|   | 17066aab97 | ||
|   | 21c9397ec1 | ||
|   | 427bcaa3f6 | ||
|   | 8fad1f55e2 | ||
|   | 140645b760 | ||
|   | b44ec7dadd | ||
|   | cafe932cbc | ||
|   | 1629a91a25 | ||
|   | c85b24862d | ||
|   | fe89b9510d | ||
|   | 0dcca35ec2 | ||
|   | c7eaee037e | ||
|   | fa201ad9ad | ||
|   | c226358f65 | ||
|   | 8fd268d59b | ||
|   | 832e3f5d49 | ||
|   | c080522102 | ||
|   | 6a1a38b395 | ||
|   | d74025bd80 | ||
|   | 413de284ed | ||
|   | d96425d19e | ||
|   | 6261fce91f | ||
|   | 46552faa2e | ||
|   | e8f655439d | ||
|   | c11093fa71 | ||
|   | af7282511a | ||
|   | 58b6cf0174 | ||
|   | 7abcb61afb | ||
|   | ff5240c0bc | ||
|   | 3852117581 | ||
|   | bf55d940b6 | ||
|   | e0ee9b1bc0 | ||
|   | 51aea90e9a | ||
|   | 7918f96f94 | ||
|   | be8faae68c | ||
|   | 04ebf0ddc9 | ||
|   | b4dece88e9 | ||
|   | d075766760 | ||
|   | 5553cbbb22 | ||
|   | bf64509216 | ||
|   | 173ba2ecf5 | ||
|   | 8e147206d8 | ||
|   | 1230da7fc7 | ||
|   | a0d328d734 | ||
|   | 4e3d935acf | ||
|   | bbc7fe6163 | ||
|   | 3fad11e104 | ||
|   | aab7631a9f | ||
|   | 38ee1724a8 | ||
|   | 0c7e2e2364 | ||
|   | f693084065 | ||
|   | a5ecc7a06d | ||
|   | 565f1543c6 | ||
|   | 0d8016d926 | ||
|   | a599e33ec2 | ||
|   | 36c84b3fec | ||
|   | 9cca389031 | ||
|   | e965507470 | ||
|   | 65fd3a3193 | ||
|   | 1d1875718d | ||
|   | 7043892e87 | ||
|   | 809c450164 | ||
|   | 3bbd8fe4c9 | ||
|   | beb308c5b3 | ||
|   | 818cb2fd76 | ||
|   | 275e01acba | ||
|   | 72135c294e | ||
|   | d0eca268ad | ||
|   | 2ed4469029 | ||
|   | 526d2a61f8 | ||
|   | 8ab00442ea | ||
|   | cba803abaf | ||
|   | 54a09ead95 | ||
|   | c2ea23f01f | ||
|   | e6bd1ae9dc | ||
|   | 7e6fd1ebe2 | ||
|   | 5e1f0c620a | ||
|   | d91934b219 | ||
|   | ff6188bd80 | ||
|   | dc1b2a6873 | ||
|   | d732a146c2 | ||
|   | b9bc518a0a | ||
|   | edf32911be | ||
|   | b8470a471b | ||
|   | 45880395ea | ||
|   | 6f3c9205cd | ||
|   | 96c90b24d1 | ||
|   | aa4bfa0727 | ||
|   | 8873ffca12 | ||
|   | 0bda748ad9 | ||
|   | 867686fe34 | ||
|   | 60f92dcdbc | ||
|   | 22f83f1614 | ||
|   | a9818b40b6 | ||
|   | 85774b7e46 | ||
|   | 886eda92a9 | ||
|   | 1d86cf01ad | ||
|   | 70b948fd17 | ||
|   | 0d98e6ca53 | ||
|   | 8d90815862 | ||
|   | 6871ad09e6 | ||
|   | 479188bc40 | ||
|   | c3c7ccd78a | ||
|   | 000b432bb2 | ||
|   | dacd2cbc30 | ||
|   | 03b5c00f03 | ||
|   | aa3a19b63c | ||
|   | 8e95cdb883 | ||
|   | 68ff352f2d | ||
|   | f02dfe60af | ||
|   | 65a08efa00 | ||
|   | 60266289e0 | ||
|   | 3145758411 | ||
|   | d7948a845d | ||
|   | aff69e583e | ||
|   | e7f7b6ad68 | ||
|   | b5e58f4076 | ||
|   | fd0f51926e | ||
|   | 733d6fe6eb | ||
|   | b2509c82b8 | ||
|   | bffbf87cb3 | ||
|   | 63890cc2fd | ||
|   | 9ade49b39c | ||
|   | 6d49cd6859 | ||
|   | 5eb116059b | ||
|   | bcdd1c56bf | ||
|   | cbcd2cce9b | ||
|   | 94c3d7fb60 | ||
|   | a2db4a464a | ||
|   | fe7da97c5c | ||
|   | c294a0a9ac | ||
|   | 30fe363b57 | ||
|   | 4ec57836d8 | ||
|   | 5b7ba838f1 | ||
|   | ac99eb59d2 | ||
|   | 1be09df9d4 | ||
|   | df858dc7b6 | ||
|   | 38b3a2080b | ||
|   | 0fec0ef624 | ||
|   | f0d6789722 | ||
|   | 7ef61d58fd | ||
|   | 96ae4a5967 | ||
|   | bca645f63d | ||
|   | a8105f084e | ||
|   | e86f09aaed | ||
|   | 692a7471c1 | ||
|   | 480645d22f | ||
|   | 784a853ec7 | ||
|   | 088fc392ab | ||
|   | 0d7644c782 | ||
|   | f15d24b4e8 | ||
|   | 510549f365 | ||
|   | 99313fe162 | ||
|   | f9df193b7b | ||
|   | 113a400952 | ||
|   | b6983e4b21 | ||
|   | fc400ea57b | ||
|   | 068a74adeb | ||
|   | 1a8743ec11 | ||
|   | 9925b9b455 | ||
|   | 4c43bae92d | ||
|   | 659db9f04b | ||
|   | b88d1dfaa9 | ||
|   | 7c79bbd6b0 | ||
|   | ce6bfcb7f5 | ||
|   | 6ce543e118 | ||
|   | cd9bf03fb7 | ||
|   | 1d88ac43cf | ||
|   | 6102285577 | ||
|   | b83603488c | ||
|   | cf22e30237 | ||
|   | f01971b67c | ||
|   | c62be1bb45 | ||
|   | cf1880343b | ||
|   | 0c57433567 | ||
|   | 5ef0527ebc | ||
|   | 53ef5c51cc | ||
|   | 58c7934dd8 | ||
|   | 0a626917f8 | ||
|   | 922bb1452f | ||
|   | 1cda37659e | ||
|   | fe2e46fe60 | ||
|   | 7765afa7da | ||
|   | 55d7e9ec61 | ||
|   | 6a4ad8af06 | ||
|   | 018440354f | ||
|   | 03c59adaed | ||
|   | 7198fe55a9 | ||
|   | 6d2904cff1 | ||
|   | 55fac29b3e | ||
|   | 5e966d60b0 | ||
|   | c08f927d60 | ||
|   | f3f25c7874 | ||
|   | 5619f8771b | ||
|   | 74a9e86e74 | ||
|   | a641fd51e8 | ||
|   | e6906563a4 | ||
|   | 2dce7f0268 | ||
|   | 6fa8a51a21 | ||
|   | 49a197eaa8 | ||
|   | 3abe7cfc45 | ||
|   | da79b371fe | ||
|   | c8d155c455 | ||
|   | f00871a6b4 | ||
|   | b4e32542e8 | ||
|   | 8c31db6352 | ||
|   | 91eb824c21 | ||
|   | 00e66c48b8 | ||
|   | 589f90762a | ||
|   | f256a57f27 | ||
|   | 1102bf271d | ||
|   | b561d5ad9a | ||
|   | a5cb58ca96 | ||
|   | 0af77a3c2c | ||
|   | a75d14f5d0 | ||
|   | bca39e8081 | ||
|   | 3e3519e8ec | ||
|   | 566150977a | ||
|   | 0ff3ba30b7 | ||
|   | 43885e6d0b | ||
|   | 577f0ca562 | ||
|   | 56d339b8f0 | ||
|   | bd1e7a7c13 | ||
|   | 5f41b65af1 | ||
|   | 3c90894e38 | ||
|   | 0dbebe953b | ||
|   | 16c12a42c7 | ||
|   | 136f1c50e7 | ||
|   | 043729f557 | ||
|   | 75f1f9228d | ||
|   | 38d9c6d26b | ||
|   | afd7cf51cf | ||
|   | c41594d220 | ||
|   | fedbd48c0f | ||
|   | 271b779995 | ||
|   | 52b33f6f47 | ||
|   | 5aee43d05b | ||
|   | 836d3a87be | ||
|   | 7b29a380fc | ||
|   | 997c23befa | ||
|   | 24d43849a0 | ||
|   | 4ce26296d6 | ||
|   | 4342759da7 | ||
|   | 25f2d224f1 | ||
|   | 8b8b828cd1 | ||
|   | 65dabeaf15 | ||
|   | 0480339272 | ||
|   | b09cdc0a18 | ||
|   | c3b86b687c | ||
|   | 0abb4f8c6f | ||
|   | ccdb803501 | ||
|   | 1e864a508d | ||
|   | 697ac18872 | ||
|   | fc229cf274 | ||
|   | b48136d994 | ||
|   | 77ba7c987a | ||
|   | 84f3baf013 | ||
|   | 5f1cfc7519 | ||
|   | e52de6c279 | ||
|   | 8a55b212a2 | ||
|   | aa7f5a8387 | ||
|   | 5fc99f1982 | ||
|   | 795baedbb1 | ||
|   | 5469a7eb71 | ||
|   | 23fc7c2c96 | ||
|   | dff404a8c9 | ||
|   | 146364aa67 | ||
|   | 258dbf30e0 | ||
|   | 44b93c039a | ||
|   | 4d5313699e | ||
|   | cd198290d7 | ||
|   | 60ed7d3273 | ||
|   | 9bcfba6620 | ||
|   | 7ea3c64268 | ||
|   | 2b6a34e9e0 | ||
|   | 458b90c78d | ||
|   | dd284c0986 | ||
|   | 21539dfb6a | ||
|   | 91785b8284 | ||
|   | f202770b70 | ||
|   | 8186a54962 | ||
|   | 866909b803 | ||
|   | 408910e6e8 | ||
|   | 24c8e575f4 | ||
|   | 8d0ca2c876 | ||
|   | fc96ebefd4 | ||
|   | 394330175f | ||
|   | f946c3da06 | ||
|   | 156fbd1958 | ||
|   | 7dd0d126e2 | ||
|   | 205360c109 | ||
|   | 984a0e6d06 | ||
|   | eb63568ceb | ||
|   | cc6f896b69 | ||
|   | 83e47a7216 | ||
|   | 1d64549cce | ||
|   | d0c36c0de3 | ||
|   | 341db13279 | ||
|   | 1c8e13b9c1 | ||
|   | 49c5f3bb9c | ||
|   | 4ae361bd1f | ||
|   | 6502496a2c | ||
|   | 8678ceeb3c | ||
|   | 9cb62f4d2e | ||
|   | 6c0ef54e18 | ||
|   | fd731c5ccd | ||
|   | cbe9490dc0 | ||
|   | 82054bfabc | ||
|   | 963dd75c39 | ||
|   | 1c24617f98 | ||
|   | 1559c2ca21 | ||
|   | 6141722b1f | ||
|   | 222d8eed4e | ||
|   | 718d52a72c | ||
|   | fe1a06271a | ||
|   | bd2370555b | ||
|   | 86c9ee4e90 | ||
|   | b26bcf1343 | ||
|   | 5d5c6275f9 | ||
|   | 9c1a47d1fc | ||
|   | 13852b7f4e | ||
|   | 4fd7a88a15 | ||
|   | 5c2a6b5eb1 | ||
|   | 9cbebbb8a0 | ||
|   | e26d987c4e | ||
|   | 53669efaf8 | ||
|   | b68f45ef59 | ||
|   | 8f44de651b | ||
|   | 2ede244da0 | ||
|   | 77a181978e | ||
|   | 170bbce0d3 | ||
|   | fc99d9be41 | ||
|   | 9fb9bed806 | ||
|   | 01b2f80a95 | ||
|   | da7ff777d1 | ||
|   | b9531d56c4 | ||
|   | 13114ebaa1 | ||
|   | e251baa61c | ||
|   | d165e8a642 | ||
|   | c10f76580f | ||
|   | c2f60568cf | ||
|   | 6518e1300f | ||
|   | 22a7234b54 | ||
|   | 67cbdb41f7 | ||
|   | 2cce8eebc3 | ||
|   | 3d5616cb35 | ||
|   | f15e8c9edb | ||
|   | a23f0da2a4 | ||
|   | 975f36c7db | ||
|   | fee2b244a1 | ||
|   | 791e67641e | ||
|   | 86e1bb38ee | ||
|   | 40e75fe9b4 | ||
|   | f979ced49d | ||
|   | fe8474f6c0 | ||
|   | 8b42302f9b | ||
|   | bee2b696aa | ||
|   | 5c69e5fdb0 | ||
|   | 8d48f8d8b0 | ||
|   | 9ee45767de | ||
|   | b193013c84 | ||
|   | a3930eb629 | ||
|   | 619ae2fb6d | ||
|   | 0605b85d99 | ||
|   | 077cc653d0 | ||
|   | cf54ddc62b | ||
|   | e7a1d8390c | ||
|   | 4202488da0 | ||
|   | f8a4488050 | ||
|   | b4618f9ba1 | ||
|   | 2c5d83fab3 | ||
|   | e0e038d223 | ||
|   | f4cb6a1927 | ||
|   | f3b939e03a | ||
|   | 12e1af44fc | ||
|   | 7dd21d85ba | ||
|   | fdd900060a | ||
|   | ebef1c4f6b | ||
|   | bbc6eb6ee7 | ||
|   | fb5d80a7a1 | ||
|   | 2740edfc2b | ||
|   | 4da9c71be9 | ||
|   | 21479b2b28 | ||
|   | 483722fb3d | ||
|   | 58bc6c7f02 | ||
|   | b243609e87 | ||
|   | f346056058 | ||
|   | f67254cdc7 | ||
|   | cc2c828e78 | ||
|   | 825f50299a | ||
|   | 1db4230d35 | ||
|   | 4736e59393 | ||
|   | 275f2002b5 | ||
|   | c2e8cb75bd | ||
|   | b746747650 | ||
|   | 1e53c121ae | 
							
								
								
									
										30
									
								
								.build/common.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.build/common.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | /** | ||||||
|  |  * Shared common options for both ESBuild and Vite | ||||||
|  |  */ | ||||||
|  | export const packageOptions = { | ||||||
|  |   parser: { | ||||||
|  |     name: 'mermaid-parser', | ||||||
|  |     packageName: 'parser', | ||||||
|  |     file: 'index.ts', | ||||||
|  |   }, | ||||||
|  |   mermaid: { | ||||||
|  |     name: 'mermaid', | ||||||
|  |     packageName: 'mermaid', | ||||||
|  |     file: 'mermaid.ts', | ||||||
|  |   }, | ||||||
|  |   'mermaid-example-diagram': { | ||||||
|  |     name: 'mermaid-example-diagram', | ||||||
|  |     packageName: 'mermaid-example-diagram', | ||||||
|  |     file: 'detector.ts', | ||||||
|  |   }, | ||||||
|  |   'mermaid-zenuml': { | ||||||
|  |     name: 'mermaid-zenuml', | ||||||
|  |     packageName: 'mermaid-zenuml', | ||||||
|  |     file: 'detector.ts', | ||||||
|  |   }, | ||||||
|  |   'mermaid-flowchart-elk': { | ||||||
|  |     name: 'mermaid-flowchart-elk', | ||||||
|  |     packageName: 'mermaid-flowchart-elk', | ||||||
|  |     file: 'detector.ts', | ||||||
|  |   }, | ||||||
|  | } as const; | ||||||
							
								
								
									
										5
									
								
								.build/generateLangium.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.build/generateLangium.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | import { generate } from 'langium-cli'; | ||||||
|  |  | ||||||
|  | export async function generateLangium() { | ||||||
|  |   await generate({ file: `./packages/parser/langium-config.json` }); | ||||||
|  | } | ||||||
							
								
								
									
										124
									
								
								.build/jsonSchema.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								.build/jsonSchema.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,124 @@ | |||||||
|  | import { load, JSON_SCHEMA } from 'js-yaml'; | ||||||
|  | import assert from 'node:assert'; | ||||||
|  | import Ajv2019, { type JSONSchemaType } from 'ajv/dist/2019.js'; | ||||||
|  | import type { MermaidConfig, BaseDiagramConfig } from '../packages/mermaid/src/config.type.js'; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * All of the keys in the mermaid config that have a mermaid diagram config. | ||||||
|  |  */ | ||||||
|  | const MERMAID_CONFIG_DIAGRAM_KEYS = [ | ||||||
|  |   'flowchart', | ||||||
|  |   'sequence', | ||||||
|  |   'gantt', | ||||||
|  |   'journey', | ||||||
|  |   'class', | ||||||
|  |   'state', | ||||||
|  |   'er', | ||||||
|  |   'pie', | ||||||
|  |   'quadrantChart', | ||||||
|  |   'xyChart', | ||||||
|  |   'requirement', | ||||||
|  |   'mindmap', | ||||||
|  |   'timeline', | ||||||
|  |   'gitGraph', | ||||||
|  |   'c4', | ||||||
|  |   'sankey', | ||||||
|  |   'block', | ||||||
|  |   'packet', | ||||||
|  | ] as const; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Generate default values from the JSON Schema. | ||||||
|  |  * | ||||||
|  |  * AJV does not support nested default values yet (or default values with $ref), | ||||||
|  |  * so we need to manually find them (this may be fixed in ajv v9). | ||||||
|  |  * | ||||||
|  |  * @param mermaidConfigSchema - The Mermaid JSON Schema to use. | ||||||
|  |  * @returns The default mermaid config object. | ||||||
|  |  */ | ||||||
|  | function generateDefaults(mermaidConfigSchema: JSONSchemaType<MermaidConfig>) { | ||||||
|  |   const ajv = new Ajv2019({ | ||||||
|  |     useDefaults: true, | ||||||
|  |     allowUnionTypes: true, | ||||||
|  |     strict: true, | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   ajv.addKeyword({ | ||||||
|  |     keyword: 'meta:enum', // used by jsonschema2md | ||||||
|  |     errors: false, | ||||||
|  |   }); | ||||||
|  |   ajv.addKeyword({ | ||||||
|  |     keyword: 'tsType', // used by json-schema-to-typescript | ||||||
|  |     errors: false, | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   // ajv currently doesn't support nested default values, see https://github.com/ajv-validator/ajv/issues/1718 | ||||||
|  |   // (may be fixed in v9) so we need to manually use sub-schemas | ||||||
|  |   const mermaidDefaultConfig = {}; | ||||||
|  |  | ||||||
|  |   assert.ok(mermaidConfigSchema.$defs); | ||||||
|  |   const baseDiagramConfig = mermaidConfigSchema.$defs.BaseDiagramConfig; | ||||||
|  |  | ||||||
|  |   for (const key of MERMAID_CONFIG_DIAGRAM_KEYS) { | ||||||
|  |     const subSchemaRef = mermaidConfigSchema.properties[key].$ref; | ||||||
|  |     const [root, defs, defName] = subSchemaRef.split('/'); | ||||||
|  |     assert.strictEqual(root, '#'); | ||||||
|  |     assert.strictEqual(defs, '$defs'); | ||||||
|  |     const subSchema = { | ||||||
|  |       $schema: mermaidConfigSchema.$schema, | ||||||
|  |       $defs: mermaidConfigSchema.$defs, | ||||||
|  |       ...mermaidConfigSchema.$defs[defName], | ||||||
|  |     } as JSONSchemaType<BaseDiagramConfig>; | ||||||
|  |  | ||||||
|  |     const validate = ajv.compile(subSchema); | ||||||
|  |  | ||||||
|  |     mermaidDefaultConfig[key] = {}; | ||||||
|  |  | ||||||
|  |     for (const required of subSchema.required ?? []) { | ||||||
|  |       if (subSchema.properties[required] === undefined && baseDiagramConfig.properties[required]) { | ||||||
|  |         mermaidDefaultConfig[key][required] = baseDiagramConfig.properties[required].default; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     if (!validate(mermaidDefaultConfig[key])) { | ||||||
|  |       throw new Error( | ||||||
|  |         `schema for subconfig ${key} does not have valid defaults! Errors were ${JSON.stringify( | ||||||
|  |           validate.errors, | ||||||
|  |           undefined, | ||||||
|  |           2 | ||||||
|  |         )}` | ||||||
|  |       ); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const validate = ajv.compile(mermaidConfigSchema); | ||||||
|  |  | ||||||
|  |   if (!validate(mermaidDefaultConfig)) { | ||||||
|  |     throw new Error( | ||||||
|  |       `Mermaid config JSON Schema does not have valid defaults! Errors were ${JSON.stringify( | ||||||
|  |         validate.errors, | ||||||
|  |         undefined, | ||||||
|  |         2 | ||||||
|  |       )}` | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return mermaidDefaultConfig; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export const loadSchema = (src: string, filename: string): JSONSchemaType<MermaidConfig> => { | ||||||
|  |   const jsonSchema = load(src, { | ||||||
|  |     filename, | ||||||
|  |     // only allow JSON types in our YAML doc (will probably be default in YAML 1.3) | ||||||
|  |     // e.g. `true` will be parsed a boolean `true`, `True` will be parsed as string `"True"`. | ||||||
|  |     schema: JSON_SCHEMA, | ||||||
|  |   }) as JSONSchemaType<MermaidConfig>; | ||||||
|  |   return jsonSchema; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const getDefaults = (schema: JSONSchemaType<MermaidConfig>) => { | ||||||
|  |   return `export default ${JSON.stringify(generateDefaults(schema), undefined, 2)};`; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const getSchema = (schema: JSONSchemaType<MermaidConfig>) => { | ||||||
|  |   return `export default ${JSON.stringify(schema, undefined, 2)};`; | ||||||
|  | }; | ||||||
							
								
								
									
										18
									
								
								.build/types.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								.build/types.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | import { packageOptions } from './common.js'; | ||||||
|  | import { execSync } from 'child_process'; | ||||||
|  |  | ||||||
|  | const buildType = (packageName: string) => { | ||||||
|  |   console.log(`Building types for ${packageName}`); | ||||||
|  |   try { | ||||||
|  |     const out = execSync(`tsc -p ./packages/${packageName}/tsconfig.json --emitDeclarationOnly`); | ||||||
|  |     out.length > 0 && console.log(out.toString()); | ||||||
|  |   } catch (e) { | ||||||
|  |     console.error(e); | ||||||
|  |     e.stdout.length > 0 && console.error(e.stdout.toString()); | ||||||
|  |     e.stderr.length > 0 && console.error(e.stderr.toString()); | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | for (const { packageName } of Object.values(packageOptions)) { | ||||||
|  |   buildType(packageName); | ||||||
|  | } | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| { |  | ||||||
|   "extends": ["@commitlint/config-conventional"] |  | ||||||
| } |  | ||||||
							
								
								
									
										140
									
								
								.cspell/code-terms.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										140
									
								
								.cspell/code-terms.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,140 @@ | |||||||
|  | # This file contains coding related terms | ||||||
|  | ALPHANUM | ||||||
|  | antiscript | ||||||
|  | APPLYCLASS | ||||||
|  | ARROWHEADSTYLE | ||||||
|  | ARROWTYPE | ||||||
|  | autonumber | ||||||
|  | axisl-line | ||||||
|  | Bigdecimal | ||||||
|  | birel | ||||||
|  | BIREL | ||||||
|  | bqstring | ||||||
|  | BQUOTE | ||||||
|  | bramp | ||||||
|  | BRKT | ||||||
|  | callbackargs | ||||||
|  | callbackname | ||||||
|  | classdef | ||||||
|  | classdefid | ||||||
|  | classentity | ||||||
|  | classname | ||||||
|  | COLONSEP | ||||||
|  | COMPOSIT_STATE | ||||||
|  | concat | ||||||
|  | controlx | ||||||
|  | controly | ||||||
|  | CSSCLASS | ||||||
|  | CYLINDEREND | ||||||
|  | CYLINDERSTART | ||||||
|  | datakey | ||||||
|  | DEND | ||||||
|  | descr | ||||||
|  | distp | ||||||
|  | distq | ||||||
|  | divs | ||||||
|  | docref | ||||||
|  | DOMID | ||||||
|  | doublecircle | ||||||
|  | DOUBLECIRCLEEND | ||||||
|  | DOUBLECIRCLESTART | ||||||
|  | DQUOTE | ||||||
|  | DSTART | ||||||
|  | edgesep | ||||||
|  | EMPTYSTR | ||||||
|  | enddate | ||||||
|  | ERDIAGRAM | ||||||
|  | flatmap | ||||||
|  | forwardable | ||||||
|  | frontmatter | ||||||
|  | funs | ||||||
|  | gantt | ||||||
|  | GENERICTYPE | ||||||
|  | getBoundarys | ||||||
|  | grammr | ||||||
|  | graphtype | ||||||
|  | iife | ||||||
|  | interp | ||||||
|  | introdcued | ||||||
|  | INVTRAPEND | ||||||
|  | INVTRAPSTART | ||||||
|  | JDBC | ||||||
|  | jison | ||||||
|  | Kaufmann | ||||||
|  | keyify | ||||||
|  | LABELPOS | ||||||
|  | LABELTYPE | ||||||
|  | lcov | ||||||
|  | LEFTOF | ||||||
|  | Lexa | ||||||
|  | linebreak | ||||||
|  | LINETYPE | ||||||
|  | LINKSTYLE | ||||||
|  | LLABEL | ||||||
|  | loglevel | ||||||
|  | LOGMSG | ||||||
|  | lookaheads | ||||||
|  | mdast | ||||||
|  | metafile | ||||||
|  | minlen | ||||||
|  | Mstartx | ||||||
|  | MULT | ||||||
|  | NODIR | ||||||
|  | NSTR | ||||||
|  | outdir | ||||||
|  | Qcontrolx | ||||||
|  | reinit | ||||||
|  | rels | ||||||
|  | reqs | ||||||
|  | rewritelinks | ||||||
|  | rgba | ||||||
|  | RIGHTOF | ||||||
|  | sankey | ||||||
|  | sequencenumber | ||||||
|  | shrc | ||||||
|  | signaltype | ||||||
|  | someclass | ||||||
|  | SPACELINE | ||||||
|  | SPACELIST | ||||||
|  | STADIUMEND | ||||||
|  | STADIUMSTART | ||||||
|  | startdate | ||||||
|  | startx | ||||||
|  | starty | ||||||
|  | STMNT | ||||||
|  | stopx | ||||||
|  | stopy | ||||||
|  | strikethrough | ||||||
|  | stringifying | ||||||
|  | struct | ||||||
|  | STYLECLASS | ||||||
|  | STYLEOPTS | ||||||
|  | subcomponent | ||||||
|  | subcomponents | ||||||
|  | SUBROUTINEEND | ||||||
|  | SUBROUTINESTART | ||||||
|  | Subschemas | ||||||
|  | substr | ||||||
|  | TAGEND | ||||||
|  | TAGSTART | ||||||
|  | techn | ||||||
|  | TESTSTR | ||||||
|  | TEXTDATA | ||||||
|  | TEXTLENGTH | ||||||
|  | titlevalue | ||||||
|  | topbar | ||||||
|  | TRAPEND | ||||||
|  | TRAPSTART | ||||||
|  | ts-nocheck | ||||||
|  | tsdoc | ||||||
|  | typeof | ||||||
|  | typestr | ||||||
|  | unshift | ||||||
|  | verifymethod | ||||||
|  | VERIFYMTHD | ||||||
|  | WARN_DOCSDIR_DOESNT_MATCH | ||||||
|  | xhost | ||||||
|  | yaxis | ||||||
|  | yfunc | ||||||
|  | yytext | ||||||
|  | zenuml | ||||||
							
								
								
									
										8
									
								
								.cspell/contributors.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.cspell/contributors.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | # Contributors to mermaidjs, one per line | ||||||
|  | Ashish Jain | ||||||
|  | cpettitt | ||||||
|  | Dong Cai | ||||||
|  | Nikolay Rozhkov | ||||||
|  | Peng Xiao | ||||||
|  | subhash-halder | ||||||
|  | Vinod Sidharth | ||||||
							
								
								
									
										52
									
								
								.cspell/cspell.config.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								.cspell/cspell.config.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | # yaml-language-server: $schema=https://raw.githubusercontent.com/streetsidesoftware/cspell/main/cspell.schema.json | ||||||
|  |  | ||||||
|  | $schema: https://raw.githubusercontent.com/streetsidesoftware/cspell/main/cspell.schema.json | ||||||
|  |  | ||||||
|  | dictionaryDefinitions: | ||||||
|  |   - name: code-terms | ||||||
|  |     path: ./code-terms.txt | ||||||
|  |     description: A list of coding related terms. | ||||||
|  |     addWords: true | ||||||
|  |   - name: mermaid-terms | ||||||
|  |     path: ./mermaid-terms.txt | ||||||
|  |     description: A list of terms related to the mermaid project. | ||||||
|  |     addWords: true | ||||||
|  |   - name: misc-terms | ||||||
|  |     path: ./misc-terms.txt | ||||||
|  |     description: A list of miscellaneous terms. | ||||||
|  |   - name: 3rd-party-terms | ||||||
|  |     path: ./libraries.txt | ||||||
|  |     description: A list of 3rd party terms from dependencies. | ||||||
|  |     addWords: true | ||||||
|  |   - name: contributors | ||||||
|  |     path: ./contributors.txt | ||||||
|  |     description: A list of contributors to the mermaid project. | ||||||
|  |     type: 'W' | ||||||
|  |     addWords: true | ||||||
|  |  | ||||||
|  |   # cspell:disable | ||||||
|  |   - name: suggestions | ||||||
|  |     words: | ||||||
|  |       - none | ||||||
|  |     suggestWords: | ||||||
|  |       - seperator:separator | ||||||
|  |       - vertice:vertex | ||||||
|  |   # cspell:enable | ||||||
|  |  | ||||||
|  | patterns: | ||||||
|  |   - name: character-set-cyrillic | ||||||
|  |     pattern: '/\p{Script_Extensions=Cyrillic}+/gu' | ||||||
|  |   - name: svg-block | ||||||
|  |     pattern: '<svg[\S\s]+?</svg>' | ||||||
|  |   - name: json-property | ||||||
|  |     pattern: '/"[\w/@-]+":/g' | ||||||
|  |  | ||||||
|  | dictionaries: | ||||||
|  |   - mermaid-terms | ||||||
|  |   - suggestions | ||||||
|  |   - contributors | ||||||
|  |  | ||||||
|  | ignorePaths: | ||||||
|  |   - '*.txt' # do not spell check local dictionaries | ||||||
|  |  | ||||||
|  | # cspell:dictionary misc-terms | ||||||
							
								
								
									
										71
									
								
								.cspell/libraries.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								.cspell/libraries.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | |||||||
|  | # Add third party library terms below | ||||||
|  | acyclicer | ||||||
|  | Antlr | ||||||
|  | Appli | ||||||
|  | applitools | ||||||
|  | Asciidoctor | ||||||
|  | Astah | ||||||
|  | automerge | ||||||
|  | bilkent | ||||||
|  | bisheng | ||||||
|  | Blazor | ||||||
|  | codedoc | ||||||
|  | Codemia | ||||||
|  | codepaths | ||||||
|  | csstree | ||||||
|  | cytoscape | ||||||
|  | cytoscape-cose-bilkent | ||||||
|  | dagre | ||||||
|  | dagre-d3 | ||||||
|  | Deepdwn | ||||||
|  | Docsify | ||||||
|  | Docsy | ||||||
|  | DokuWiki | ||||||
|  | dompurify | ||||||
|  | elkjs | ||||||
|  | fontawesome | ||||||
|  | Foswiki | ||||||
|  | Gitea | ||||||
|  | graphlib | ||||||
|  | Grav | ||||||
|  | iconify | ||||||
|  | Inkdrop | ||||||
|  | jiti | ||||||
|  | jsdocs | ||||||
|  | jsfiddle | ||||||
|  | jsonschema | ||||||
|  | katex | ||||||
|  | khroma | ||||||
|  | langium | ||||||
|  | mathml | ||||||
|  | matplotlib | ||||||
|  | mdbook | ||||||
|  | Mermerd | ||||||
|  | mkdocs | ||||||
|  | Nextra | ||||||
|  | nodenext | ||||||
|  | npmjs | ||||||
|  | pageview | ||||||
|  | pathe | ||||||
|  | phpbb | ||||||
|  | pixelmatch | ||||||
|  | Podlite | ||||||
|  | presetAttributify | ||||||
|  | pyplot | ||||||
|  | redmine | ||||||
|  | rehype | ||||||
|  | rscratch | ||||||
|  | sparkline | ||||||
|  | sphinxcontrib | ||||||
|  | ssim | ||||||
|  | stylis | ||||||
|  | Swimm | ||||||
|  | tsbuildinfo | ||||||
|  | Tuleap | ||||||
|  | Typora | ||||||
|  | unocss | ||||||
|  | unplugin | ||||||
|  | unstub | ||||||
|  | vite | ||||||
|  | vitest | ||||||
|  | Zune | ||||||
							
								
								
									
										39
									
								
								.cspell/mermaid-terms.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								.cspell/mermaid-terms.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | |||||||
|  | Adamiecki | ||||||
|  | arrowend | ||||||
|  | bmatrix | ||||||
|  | braintree | ||||||
|  | catmull | ||||||
|  | compositTitleSize | ||||||
|  | doublecircle | ||||||
|  | elems | ||||||
|  | gantt | ||||||
|  | gitgraph | ||||||
|  | gzipped | ||||||
|  | knsv | ||||||
|  | Knut | ||||||
|  | marginx | ||||||
|  | marginy | ||||||
|  | Markdownish | ||||||
|  | mermaidjs | ||||||
|  | mindmap | ||||||
|  | mindmaps | ||||||
|  | multigraph | ||||||
|  | nodesep | ||||||
|  | NOTEGROUP | ||||||
|  | Pinterest | ||||||
|  | rankdir | ||||||
|  | ranksep | ||||||
|  | rect | ||||||
|  | rects | ||||||
|  | sandboxed | ||||||
|  | siebling | ||||||
|  | statediagram | ||||||
|  | substate | ||||||
|  | Sveidqvist | ||||||
|  | unfixable | ||||||
|  | Viewbox | ||||||
|  | viewports | ||||||
|  | visio | ||||||
|  | vitepress | ||||||
|  | xlink | ||||||
|  | xychart | ||||||
							
								
								
									
										1
									
								
								.cspell/misc-terms.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.cspell/misc-terms.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | newbranch | ||||||
							
								
								
									
										65
									
								
								.esbuild/build.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								.esbuild/build.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | import { build } from 'esbuild'; | ||||||
|  | import { mkdir, writeFile } from 'node:fs/promises'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  | import { generateLangium } from '../.build/generateLangium.js'; | ||||||
|  | import { MermaidBuildOptions, defaultOptions, getBuildConfig } from './util.js'; | ||||||
|  |  | ||||||
|  | const shouldVisualize = process.argv.includes('--visualize'); | ||||||
|  |  | ||||||
|  | const buildPackage = async (entryName: keyof typeof packageOptions) => { | ||||||
|  |   const commonOptions = { ...defaultOptions, entryName } as const; | ||||||
|  |   const buildConfigs = [ | ||||||
|  |     // package.mjs | ||||||
|  |     { ...commonOptions }, | ||||||
|  |     // package.min.mjs | ||||||
|  |     { | ||||||
|  |       ...commonOptions, | ||||||
|  |       minify: true, | ||||||
|  |       metafile: shouldVisualize, | ||||||
|  |     }, | ||||||
|  |     // package.core.mjs | ||||||
|  |     { ...commonOptions, core: true }, | ||||||
|  |   ]; | ||||||
|  |  | ||||||
|  |   if (entryName === 'mermaid') { | ||||||
|  |     const iifeOptions: MermaidBuildOptions = { ...commonOptions, format: 'iife' }; | ||||||
|  |     buildConfigs.push( | ||||||
|  |       // mermaid.js | ||||||
|  |       { ...iifeOptions }, | ||||||
|  |       // mermaid.min.js | ||||||
|  |       { ...iifeOptions, minify: true, metafile: shouldVisualize } | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const results = await Promise.all(buildConfigs.map((option) => build(getBuildConfig(option)))); | ||||||
|  |  | ||||||
|  |   if (shouldVisualize) { | ||||||
|  |     for (const { metafile } of results) { | ||||||
|  |       if (!metafile) { | ||||||
|  |         continue; | ||||||
|  |       } | ||||||
|  |       const fileName = Object.keys(metafile.outputs) | ||||||
|  |         .filter((file) => !file.includes('chunks') && file.endsWith('js'))[0] | ||||||
|  |         .replace('dist/', ''); | ||||||
|  |       // Upload metafile into https://esbuild.github.io/analyze/ | ||||||
|  |       await writeFile(`stats/${fileName}.meta.json`, JSON.stringify(metafile)); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const handler = (e) => { | ||||||
|  |   console.error(e); | ||||||
|  |   process.exit(1); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const main = async () => { | ||||||
|  |   await generateLangium(); | ||||||
|  |   await mkdir('stats').catch(() => {}); | ||||||
|  |   const packageNames = Object.keys(packageOptions) as (keyof typeof packageOptions)[]; | ||||||
|  |   // it should build `parser` before `mermaid` because it's a dependency | ||||||
|  |   for (const pkg of packageNames) { | ||||||
|  |     await buildPackage(pkg).catch(handler); | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | void main(); | ||||||
							
								
								
									
										15
									
								
								.esbuild/jisonPlugin.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								.esbuild/jisonPlugin.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | import { readFile } from 'node:fs/promises'; | ||||||
|  | import { transformJison } from '../.build/jisonTransformer.js'; | ||||||
|  | import { Plugin } from 'esbuild'; | ||||||
|  |  | ||||||
|  | export const jisonPlugin: Plugin = { | ||||||
|  |   name: 'jison', | ||||||
|  |   setup(build) { | ||||||
|  |     build.onLoad({ filter: /\.jison$/ }, async (args) => { | ||||||
|  |       // Load the file from the file system | ||||||
|  |       const source = await readFile(args.path, 'utf8'); | ||||||
|  |       const contents = transformJison(source); | ||||||
|  |       return { contents, warnings: [] }; | ||||||
|  |     }); | ||||||
|  |   }, | ||||||
|  | }; | ||||||
							
								
								
									
										35
									
								
								.esbuild/jsonSchemaPlugin.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								.esbuild/jsonSchemaPlugin.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | import type { JSONSchemaType } from 'ajv/dist/2019.js'; | ||||||
|  | import type { MermaidConfig } from '../packages/mermaid/src/config.type.js'; | ||||||
|  | import { readFile } from 'node:fs/promises'; | ||||||
|  | import { getDefaults, getSchema, loadSchema } from '../.build/jsonSchema.js'; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * ESBuild plugin that handles JSON Schemas saved as a `.schema.yaml` file. | ||||||
|  |  * | ||||||
|  |  * Use `my-example.schema.yaml?only-defaults=true` to only load the default values. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | export const jsonSchemaPlugin = { | ||||||
|  |   name: 'json-schema-plugin', | ||||||
|  |   setup(build) { | ||||||
|  |     let schema: JSONSchemaType<MermaidConfig> | undefined = undefined; | ||||||
|  |     let content = ''; | ||||||
|  |  | ||||||
|  |     build.onLoad({ filter: /config\.schema\.yaml$/ }, async (args) => { | ||||||
|  |       // Load the file from the file system | ||||||
|  |       const source = await readFile(args.path, 'utf8'); | ||||||
|  |       const resolvedSchema: JSONSchemaType<MermaidConfig> = | ||||||
|  |         content === source && schema ? schema : loadSchema(source, args.path); | ||||||
|  |       if (content !== source) { | ||||||
|  |         content = source; | ||||||
|  |         schema = resolvedSchema; | ||||||
|  |       } | ||||||
|  |       const contents = args.suffix.includes('only-defaults') | ||||||
|  |         ? getDefaults(resolvedSchema) | ||||||
|  |         : getSchema(resolvedSchema); | ||||||
|  |       return { contents, warnings: [] }; | ||||||
|  |     }); | ||||||
|  |   }, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export default jsonSchemaPlugin; | ||||||
							
								
								
									
										102
									
								
								.esbuild/server.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								.esbuild/server.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | |||||||
|  | import express from 'express'; | ||||||
|  | import type { NextFunction, Request, Response } from 'express'; | ||||||
|  | import cors from 'cors'; | ||||||
|  | import { getBuildConfig, defaultOptions } from './util.js'; | ||||||
|  | import { context } from 'esbuild'; | ||||||
|  | import chokidar from 'chokidar'; | ||||||
|  | import { generateLangium } from '../.build/generateLangium.js'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  |  | ||||||
|  | const configs = Object.values(packageOptions).map(({ packageName }) => | ||||||
|  |   getBuildConfig({ ...defaultOptions, minify: false, core: false, entryName: packageName }) | ||||||
|  | ); | ||||||
|  | const mermaidIIFEConfig = getBuildConfig({ | ||||||
|  |   ...defaultOptions, | ||||||
|  |   minify: false, | ||||||
|  |   core: false, | ||||||
|  |   entryName: 'mermaid', | ||||||
|  |   format: 'iife', | ||||||
|  | }); | ||||||
|  | configs.push(mermaidIIFEConfig); | ||||||
|  |  | ||||||
|  | const contexts = await Promise.all(configs.map((config) => context(config))); | ||||||
|  |  | ||||||
|  | const rebuildAll = async () => { | ||||||
|  |   console.time('Rebuild time'); | ||||||
|  |   await Promise.all(contexts.map((ctx) => ctx.rebuild())).catch((e) => console.error(e)); | ||||||
|  |   console.timeEnd('Rebuild time'); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | let clients: { id: number; response: Response }[] = []; | ||||||
|  | function eventsHandler(request: Request, response: Response, next: NextFunction) { | ||||||
|  |   const headers = { | ||||||
|  |     'Content-Type': 'text/event-stream', | ||||||
|  |     Connection: 'keep-alive', | ||||||
|  |     'Cache-Control': 'no-cache', | ||||||
|  |   }; | ||||||
|  |   response.writeHead(200, headers); | ||||||
|  |   const clientId = Date.now(); | ||||||
|  |   clients.push({ | ||||||
|  |     id: clientId, | ||||||
|  |     response, | ||||||
|  |   }); | ||||||
|  |   request.on('close', () => { | ||||||
|  |     clients = clients.filter((client) => client.id !== clientId); | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | let timeoutId: NodeJS.Timeout | undefined = undefined; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Debounce file change events to avoid rebuilding multiple times. | ||||||
|  |  */ | ||||||
|  | function handleFileChange() { | ||||||
|  |   if (timeoutId !== undefined) { | ||||||
|  |     clearTimeout(timeoutId); | ||||||
|  |   } | ||||||
|  |   timeoutId = setTimeout(async () => { | ||||||
|  |     await rebuildAll(); | ||||||
|  |     sendEventsToAll(); | ||||||
|  |     timeoutId = undefined; | ||||||
|  |   }, 100); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function sendEventsToAll() { | ||||||
|  |   clients.forEach(({ response }) => response.write(`data: ${Date.now()}\n\n`)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function createServer() { | ||||||
|  |   await generateLangium(); | ||||||
|  |   handleFileChange(); | ||||||
|  |   const app = express(); | ||||||
|  |   chokidar | ||||||
|  |     .watch('**/src/**/*.{js,ts,langium,yaml,json}', { | ||||||
|  |       ignoreInitial: true, | ||||||
|  |       ignored: [/node_modules/, /dist/, /docs/, /coverage/], | ||||||
|  |     }) | ||||||
|  |     .on('all', async (event, path) => { | ||||||
|  |       // Ignore other events. | ||||||
|  |       if (!['add', 'change'].includes(event)) { | ||||||
|  |         return; | ||||||
|  |       } | ||||||
|  |       if (/\.langium$/.test(path)) { | ||||||
|  |         await generateLangium(); | ||||||
|  |       } | ||||||
|  |       console.log(`${path} changed. Rebuilding...`); | ||||||
|  |       handleFileChange(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |   app.use(cors()); | ||||||
|  |   app.get('/events', eventsHandler); | ||||||
|  |   for (const { packageName } of Object.values(packageOptions)) { | ||||||
|  |     app.use(express.static(`./packages/${packageName}/dist`)); | ||||||
|  |   } | ||||||
|  |   app.use(express.static('demos')); | ||||||
|  |   app.use(express.static('cypress/platform')); | ||||||
|  |  | ||||||
|  |   app.listen(9000, () => { | ||||||
|  |     console.log(`Listening on http://localhost:9000`); | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | createServer(); | ||||||
							
								
								
									
										101
									
								
								.esbuild/util.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								.esbuild/util.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,101 @@ | |||||||
|  | import { resolve } from 'path'; | ||||||
|  | import { fileURLToPath } from 'url'; | ||||||
|  | import type { BuildOptions } from 'esbuild'; | ||||||
|  | import { readFileSync } from 'fs'; | ||||||
|  | import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  | import { jisonPlugin } from './jisonPlugin.js'; | ||||||
|  |  | ||||||
|  | const __dirname = fileURLToPath(new URL('.', import.meta.url)); | ||||||
|  |  | ||||||
|  | export interface MermaidBuildOptions { | ||||||
|  |   minify: boolean; | ||||||
|  |   core: boolean; | ||||||
|  |   metafile: boolean; | ||||||
|  |   format: 'esm' | 'iife'; | ||||||
|  |   entryName: keyof typeof packageOptions; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export const defaultOptions: Omit<MermaidBuildOptions, 'entryName'> = { | ||||||
|  |   minify: false, | ||||||
|  |   metafile: false, | ||||||
|  |   core: false, | ||||||
|  |   format: 'esm', | ||||||
|  | } as const; | ||||||
|  |  | ||||||
|  | const buildOptions = (override: BuildOptions): BuildOptions => { | ||||||
|  |   return { | ||||||
|  |     bundle: true, | ||||||
|  |     minify: true, | ||||||
|  |     keepNames: true, | ||||||
|  |     platform: 'browser', | ||||||
|  |     tsconfig: 'tsconfig.json', | ||||||
|  |     resolveExtensions: ['.ts', '.js', '.json', '.jison', '.yaml'], | ||||||
|  |     external: ['require', 'fs', 'path'], | ||||||
|  |     outdir: 'dist', | ||||||
|  |     plugins: [jisonPlugin, jsonSchemaPlugin], | ||||||
|  |     sourcemap: 'external', | ||||||
|  |     ...override, | ||||||
|  |   }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const getFileName = (fileName: string, { core, format, minify }: MermaidBuildOptions) => { | ||||||
|  |   if (core) { | ||||||
|  |     fileName += '.core'; | ||||||
|  |   } else if (format === 'esm') { | ||||||
|  |     fileName += '.esm'; | ||||||
|  |   } | ||||||
|  |   if (minify) { | ||||||
|  |     fileName += '.min'; | ||||||
|  |   } | ||||||
|  |   return fileName; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export const getBuildConfig = (options: MermaidBuildOptions): BuildOptions => { | ||||||
|  |   const { core, entryName, metafile, format, minify } = options; | ||||||
|  |   const external: string[] = ['require', 'fs', 'path']; | ||||||
|  |   const { name, file, packageName } = packageOptions[entryName]; | ||||||
|  |   const outFileName = getFileName(name, options); | ||||||
|  |   let output: BuildOptions = buildOptions({ | ||||||
|  |     absWorkingDir: resolve(__dirname, `../packages/${packageName}`), | ||||||
|  |     entryPoints: { | ||||||
|  |       [outFileName]: `src/${file}`, | ||||||
|  |     }, | ||||||
|  |     metafile, | ||||||
|  |     minify, | ||||||
|  |     logLevel: 'info', | ||||||
|  |     chunkNames: `chunks/${outFileName}/[name]-[hash]`, | ||||||
|  |     define: { | ||||||
|  |       'import.meta.vitest': 'undefined', | ||||||
|  |     }, | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   if (core) { | ||||||
|  |     const { dependencies } = JSON.parse( | ||||||
|  |       readFileSync(resolve(__dirname, `../packages/${packageName}/package.json`), 'utf-8') | ||||||
|  |     ); | ||||||
|  |     // Core build is used to generate file without bundled dependencies. | ||||||
|  |     // This is used by downstream projects to bundle dependencies themselves. | ||||||
|  |     // Ignore dependencies and any dependencies of dependencies | ||||||
|  |     external.push(...Object.keys(dependencies)); | ||||||
|  |     output.external = external; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (format === 'iife') { | ||||||
|  |     output.format = 'iife'; | ||||||
|  |     output.splitting = false; | ||||||
|  |     output.globalName = '__esbuild_esm_mermaid'; | ||||||
|  |     // Workaround for removing the .default access in esbuild IIFE. | ||||||
|  |     // https://github.com/mermaid-js/mermaid/pull/4109#discussion_r1292317396 | ||||||
|  |     output.footer = { | ||||||
|  |       js: 'globalThis.mermaid = globalThis.__esbuild_esm_mermaid.default;', | ||||||
|  |     }; | ||||||
|  |     output.outExtension = { '.js': '.js' }; | ||||||
|  |   } else { | ||||||
|  |     output.format = 'esm'; | ||||||
|  |     output.splitting = true; | ||||||
|  |     output.outExtension = { '.js': '.mjs' }; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return output; | ||||||
|  | }; | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| dist/** |  | ||||||
| .github/** |  | ||||||
| docs/Setup.md |  | ||||||
| cypress.config.js |  | ||||||
| cypress/plugins/index.js |  | ||||||
| coverage |  | ||||||
| *.json |  | ||||||
| node_modules |  | ||||||
							
								
								
									
										1
									
								
								.eslintignore
									
									
									
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								.eslintignore
									
									
									
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | .gitignore | ||||||
| @@ -14,7 +14,7 @@ module.exports = { | |||||||
|     }, |     }, | ||||||
|     tsconfigRootDir: __dirname, |     tsconfigRootDir: __dirname, | ||||||
|     sourceType: 'module', |     sourceType: 'module', | ||||||
|     ecmaVersion: 2020, |     ecmaVersion: 2022, | ||||||
|     allowAutomaticSingleRunInference: true, |     allowAutomaticSingleRunInference: true, | ||||||
|     project: ['./tsconfig.eslint.json', './packages/*/tsconfig.json'], |     project: ['./tsconfig.eslint.json', './packages/*/tsconfig.json'], | ||||||
|     parser: '@typescript-eslint/parser', |     parser: '@typescript-eslint/parser', | ||||||
| @@ -23,7 +23,7 @@ module.exports = { | |||||||
|     'eslint:recommended', |     'eslint:recommended', | ||||||
|     'plugin:@typescript-eslint/recommended', |     'plugin:@typescript-eslint/recommended', | ||||||
|     'plugin:json/recommended', |     'plugin:json/recommended', | ||||||
|     'plugin:markdown/recommended', |     'plugin:markdown/recommended-legacy', | ||||||
|     'plugin:@cspell/recommended', |     'plugin:@cspell/recommended', | ||||||
|     'prettier', |     'prettier', | ||||||
|   ], |   ], | ||||||
| @@ -53,6 +53,7 @@ module.exports = { | |||||||
|     '@typescript-eslint/no-floating-promises': 'error', |     '@typescript-eslint/no-floating-promises': 'error', | ||||||
|     '@typescript-eslint/no-misused-promises': 'error', |     '@typescript-eslint/no-misused-promises': 'error', | ||||||
|     '@typescript-eslint/no-unused-vars': 'warn', |     '@typescript-eslint/no-unused-vars': 'warn', | ||||||
|  |     '@typescript-eslint/consistent-type-definitions': 'error', | ||||||
|     '@typescript-eslint/ban-ts-comment': [ |     '@typescript-eslint/ban-ts-comment': [ | ||||||
|       'error', |       'error', | ||||||
|       { |       { | ||||||
| @@ -63,13 +64,24 @@ module.exports = { | |||||||
|         minimumDescriptionLength: 10, |         minimumDescriptionLength: 10, | ||||||
|       }, |       }, | ||||||
|     ], |     ], | ||||||
|  |     '@typescript-eslint/naming-convention': [ | ||||||
|  |       'error', | ||||||
|  |       { | ||||||
|  |         selector: 'typeLike', | ||||||
|  |         format: ['PascalCase'], | ||||||
|  |         custom: { | ||||||
|  |           regex: '^I[A-Z]', | ||||||
|  |           match: false, | ||||||
|  |         }, | ||||||
|  |       }, | ||||||
|  |     ], | ||||||
|     'json/*': ['error', 'allowComments'], |     'json/*': ['error', 'allowComments'], | ||||||
|     '@cspell/spellchecker': [ |     '@cspell/spellchecker': [ | ||||||
|       'error', |       'error', | ||||||
|       { |       { | ||||||
|         checkIdentifiers: false, |         checkIdentifiers: true, | ||||||
|         checkStrings: false, |         checkStrings: true, | ||||||
|         checkStringTemplates: false, |         checkStringTemplates: true, | ||||||
|       }, |       }, | ||||||
|     ], |     ], | ||||||
|     'no-empty': [ |     'no-empty': [ | ||||||
| @@ -148,6 +160,19 @@ module.exports = { | |||||||
|         '@typescript-eslint/no-unused-vars': 'off', |         '@typescript-eslint/no-unused-vars': 'off', | ||||||
|       }, |       }, | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |       files: ['*.spec.{ts,js}', 'tests/**', 'cypress/**/*.js'], | ||||||
|  |       rules: { | ||||||
|  |         '@cspell/spellchecker': [ | ||||||
|  |           'error', | ||||||
|  |           { | ||||||
|  |             checkIdentifiers: false, | ||||||
|  |             checkStrings: false, | ||||||
|  |             checkStringTemplates: false, | ||||||
|  |           }, | ||||||
|  |         ], | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|       files: ['*.html', '*.md', '**/*.md/*'], |       files: ['*.html', '*.md', '**/*.md/*'], | ||||||
|       rules: { |       rules: { | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							| @@ -3,9 +3,9 @@ contact_links: | |||||||
|   - name: GitHub Discussions |   - name: GitHub Discussions | ||||||
|     url: https://github.com/mermaid-js/mermaid/discussions |     url: https://github.com/mermaid-js/mermaid/discussions | ||||||
|     about: Ask the Community questions or share your own graphs in our discussions. |     about: Ask the Community questions or share your own graphs in our discussions. | ||||||
|   - name: Slack |   - name: Discord | ||||||
|     url: https://join.slack.com/t/mermaid-talk/shared_invite/enQtNzc4NDIyNzk4OTAyLWVhYjQxOTI2OTg4YmE1ZmJkY2Y4MTU3ODliYmIwOTY3NDJlYjA0YjIyZTdkMDMyZTUwOGI0NjEzYmEwODcwOTE |     url: https://discord.gg/AgrbSrBer3 | ||||||
|     about: Join our Community on Slack for Help and a casual chat. |     about: Join our Community on Discord for Help and a casual chat. | ||||||
|   - name: Documentation |   - name: Documentation | ||||||
|     url: https://mermaid.js.org |     url: https://mermaid.js.org | ||||||
|     about: Read our documentation for all that Mermaid.js can offer. |     about: Read our documentation for all that Mermaid.js can offer. | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								.github/codecov.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/codecov.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -15,3 +15,4 @@ coverage: | |||||||
|       # Turing off for now as code coverage isn't stable and causes unnecessary build failures. |       # Turing off for now as code coverage isn't stable and causes unnecessary build failures. | ||||||
|       # default: |       # default: | ||||||
|       #   threshold: 2% |       #   threshold: 2% | ||||||
|  |     patch: off | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								.github/lychee.toml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/lychee.toml
									
									
									
									
										vendored
									
									
								
							| @@ -34,8 +34,14 @@ exclude = [ | |||||||
| # Don't check files that are generated during the build via `pnpm docs:code` | # Don't check files that are generated during the build via `pnpm docs:code` | ||||||
| 'packages/mermaid/src/docs/config/setup/*', | 'packages/mermaid/src/docs/config/setup/*', | ||||||
|  |  | ||||||
| # Ignore slack invite | # Ignore Discord invite | ||||||
| "https://join.slack.com/" | "https://discord.gg", | ||||||
|  |  | ||||||
|  | # BundlePhobia has frequent downtime | ||||||
|  | "https://bundlephobia.com", | ||||||
|  |  | ||||||
|  | # Chrome webstore migration issue. Temporary | ||||||
|  | "https://chromewebstore.google.com" | ||||||
| ] | ] | ||||||
|  |  | ||||||
| # Exclude all private IPs from checking. | # Exclude all private IPs from checking. | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
								
							| @@ -12,7 +12,7 @@ Describe the way your implementation works or what design decisions you made if | |||||||
|  |  | ||||||
| Make sure you | Make sure you | ||||||
|  |  | ||||||
| - [ ] :book: have read the [contribution guidelines](https://github.com/mermaid-js/mermaid/blob/develop/CONTRIBUTING.md) | - [ ] :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://github.com/mermaid-js/mermaid/blob/develop/packages/mermaid/src/docs/community/contributing.md#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 | - [ ] :bookmark: targeted `develop` branch | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/build-docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build-docs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -24,7 +24,7 @@ jobs: | |||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version: 18 |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Install Packages |       - name: Install Packages | ||||||
|         run: pnpm install --frozen-lockfile |         run: pnpm install --frozen-lockfile | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -15,20 +15,17 @@ permissions: | |||||||
| jobs: | jobs: | ||||||
|   build-mermaid: |   build-mermaid: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         node-version: [18.x] |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v2 |       - uses: pnpm/action-setup@v2 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js ${{ matrix.node-version }} |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version: ${{ matrix.node-version }} |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Install Packages |       - name: Install Packages | ||||||
|         run: | |         run: | | ||||||
| @@ -40,13 +37,13 @@ jobs: | |||||||
|         run: pnpm run build |         run: pnpm run build | ||||||
|  |  | ||||||
|       - name: Upload Mermaid Build as Artifact |       - name: Upload Mermaid Build as Artifact | ||||||
|         uses: actions/upload-artifact@v3 |         uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: mermaid-build |           name: mermaid-build | ||||||
|           path: packages/mermaid/dist |           path: packages/mermaid/dist | ||||||
|  |  | ||||||
|       - name: Upload Mermaid Mindmap Build as Artifact |       - name: Upload Mermaid Mindmap Build as Artifact | ||||||
|         uses: actions/upload-artifact@v3 |         uses: actions/upload-artifact@v4 | ||||||
|         with: |         with: | ||||||
|           name: mermaid-mindmap-build |           name: mermaid-mindmap-build | ||||||
|           path: packages/mermaid-mindmap/dist |           path: packages/mermaid-mindmap/dist | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -33,7 +33,7 @@ jobs: | |||||||
|  |  | ||||||
|       # Initializes the CodeQL tools for scanning. |       # Initializes the CodeQL tools for scanning. | ||||||
|       - name: Initialize CodeQL |       - name: Initialize CodeQL | ||||||
|         uses: github/codeql-action/init@v2 |         uses: github/codeql-action/init@v3 | ||||||
|         with: |         with: | ||||||
|           config-file: ./.github/codeql/codeql-config.yml |           config-file: ./.github/codeql/codeql-config.yml | ||||||
|           languages: ${{ matrix.language }} |           languages: ${{ matrix.language }} | ||||||
| @@ -45,7 +45,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@v2 |         uses: github/codeql-action/autobuild@v3 | ||||||
|  |  | ||||||
|       # ℹ️ 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 +59,4 @@ jobs: | |||||||
|       #   make release |       #   make release | ||||||
|  |  | ||||||
|       - name: Perform CodeQL Analysis |       - name: Perform CodeQL Analysis | ||||||
|         uses: github/codeql-action/analyze@v2 |         uses: github/codeql-action/analyze@v3 | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/dependency-review.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/dependency-review.yml
									
									
									
									
										vendored
									
									
								
							| @@ -17,4 +17,4 @@ jobs: | |||||||
|       - name: 'Checkout Repository' |       - name: 'Checkout Repository' | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|       - name: 'Dependency Review' |       - name: 'Dependency Review' | ||||||
|         uses: actions/dependency-review-action@v3 |         uses: actions/dependency-review-action@v4 | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								.github/workflows/e2e-applitools.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/e2e-applitools.yml
									
									
									
									
										vendored
									
									
								
							| @@ -21,9 +21,9 @@ env: | |||||||
| jobs: | jobs: | ||||||
|   e2e-applitools: |   e2e-applitools: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     strategy: |     container: | ||||||
|       matrix: |       image: cypress/browsers:node-20.11.0-chrome-121.0.6167.85-1-ff-120.0-edge-121.0.2277.83-1 | ||||||
|         node-version: [18.x] |       options: --user 1001 | ||||||
|     steps: |     steps: | ||||||
|       - if: ${{ ! env.USE_APPLI }} |       - if: ${{ ! env.USE_APPLI }} | ||||||
|         name: Warn if not using Applitools |         name: Warn if not using Applitools | ||||||
| @@ -35,10 +35,10 @@ jobs: | |||||||
|       - uses: pnpm/action-setup@v2 |       - uses: pnpm/action-setup@v2 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js ${{ matrix.node-version }} |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           node-version: ${{ matrix.node-version }} |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - if: ${{ env.USE_APPLI }} |       - if: ${{ env.USE_APPLI }} | ||||||
|         name: Notify applitools of new batch |         name: Notify applitools of new batch | ||||||
|   | |||||||
							
								
								
									
										70
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										70
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							| @@ -17,20 +17,32 @@ permissions: | |||||||
|   contents: read |   contents: read | ||||||
|  |  | ||||||
| env: | env: | ||||||
|   # For PRs and MergeQueues, the target commit is used, and for push events, github.event.previous is used. |   # For PRs and MergeQueues, the target commit is used, and for push events to non-develop branches, github.event.previous is used if available. Otherwise, 'develop' is used. | ||||||
|   targetHash: ${{ github.event.pull_request.base.sha || github.event.merge_group.base_sha || github.event.before }} |   targetHash: >- | ||||||
|  |     ${{  | ||||||
|  |       github.event.pull_request.base.sha ||  | ||||||
|  |       github.event.merge_group.base_sha ||  | ||||||
|  |       ( | ||||||
|  |         ( | ||||||
|  |           (github.event_name == 'push' && github.ref == 'refs/heads/develop') ||  | ||||||
|  |           github.event.before == '0000000000000000000000000000000000000000' | ||||||
|  |         ) && 'develop' | ||||||
|  |       ) ||  | ||||||
|  |       github.event.before | ||||||
|  |     }} | ||||||
| jobs: | jobs: | ||||||
|   cache: |   cache: | ||||||
|     runs-on: ubuntu-latest |     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: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - uses: pnpm/action-setup@v2 |       - uses: pnpm/action-setup@v2 | ||||||
|       - name: Setup Node.js |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           node-version: 18.x |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Cache snapshots |       - name: Cache snapshots | ||||||
|         id: cache-snapshot |         id: cache-snapshot | ||||||
|         uses: actions/cache@v4 |         uses: actions/cache@v4 | ||||||
| @@ -46,22 +58,39 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           ref: ${{ env.targetHash }} |           ref: ${{ env.targetHash }} | ||||||
|  |  | ||||||
|  |       - name: Install dependencies | ||||||
|  |         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} | ||||||
|  |         uses: cypress-io/github-action@v6 | ||||||
|  |         with: | ||||||
|  |           # just perform install | ||||||
|  |           runTests: false | ||||||
|  |  | ||||||
|  |       - name: Calculate bundle size | ||||||
|  |         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true'}} | ||||||
|  |         run: | | ||||||
|  |           pnpm run build:viz | ||||||
|  |           mkdir -p cypress/snapshots/stats/base | ||||||
|  |           mv stats cypress/snapshots/stats/base | ||||||
|  |  | ||||||
|       - name: Cypress run |       - name: Cypress run | ||||||
|         uses: cypress-io/github-action@v4 |         uses: cypress-io/github-action@v6 | ||||||
|         id: cypress-snapshot-gen |         id: cypress-snapshot-gen | ||||||
|         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} |         if: ${{ steps.cache-snapshot.outputs.cache-hit != 'true' }} | ||||||
|         with: |         with: | ||||||
|  |           install: false | ||||||
|           start: pnpm run dev |           start: pnpm run dev | ||||||
|           wait-on: 'http://localhost:9000' |           wait-on: 'http://localhost:9000' | ||||||
|           browser: chrome |           browser: chrome | ||||||
|  |  | ||||||
|   e2e: |   e2e: | ||||||
|     runs-on: ubuntu-latest |     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 | ||||||
|     needs: cache |     needs: cache | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         node-version: [18.x] |  | ||||||
|         containers: [1, 2, 3, 4] |         containers: [1, 2, 3, 4] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| @@ -69,28 +98,43 @@ jobs: | |||||||
|       - uses: pnpm/action-setup@v2 |       - uses: pnpm/action-setup@v2 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js ${{ matrix.node-version }} |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           node-version: ${{ matrix.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@v3 |         uses: actions/cache/restore@v4 | ||||||
|         with: |         with: | ||||||
|           path: ./cypress/snapshots |           path: ./cypress/snapshots | ||||||
|           key: ${{ runner.os }}-snapshots-${{ env.targetHash }} |           key: ${{ runner.os }}-snapshots-${{ env.targetHash }} | ||||||
|  |  | ||||||
|  |       - name: Install dependencies | ||||||
|  |         uses: cypress-io/github-action@v6 | ||||||
|  |         with: | ||||||
|  |           runTests: false | ||||||
|  |  | ||||||
|  |       - name: Output size diff | ||||||
|  |         if: ${{ matrix.containers == 1 }} | ||||||
|  |         run: | | ||||||
|  |           pnpm run build:viz | ||||||
|  |           mv stats cypress/snapshots/stats/head | ||||||
|  |           echo '## Bundle size difference' >> "$GITHUB_STEP_SUMMARY" | ||||||
|  |           echo '' >> "$GITHUB_STEP_SUMMARY" | ||||||
|  |           npx tsx scripts/size.ts >> "$GITHUB_STEP_SUMMARY" | ||||||
|  |  | ||||||
|       # 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@v4 |         uses: cypress-io/github-action@v6 | ||||||
|         id: cypress |         id: cypress | ||||||
|         # If CYPRESS_RECORD_KEY is set, run in parallel on all containers |         # 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 |         # Otherwise (e.g. if running from fork), we run on a single container only | ||||||
|         if: ${{ ( env.CYPRESS_RECORD_KEY != '' ) || ( matrix.containers == 1 ) }} |         if: ${{ ( env.CYPRESS_RECORD_KEY != '' ) || ( matrix.containers == 1 ) }} | ||||||
|         with: |         with: | ||||||
|  |           install: false | ||||||
|           start: pnpm run dev:coverage |           start: pnpm run dev:coverage | ||||||
|           wait-on: 'http://localhost:9000' |           wait-on: 'http://localhost:9000' | ||||||
|           browser: chrome |           browser: chrome | ||||||
| @@ -104,7 +148,7 @@ jobs: | |||||||
|           CYPRESS_COMMIT: ${{ github.sha }} |           CYPRESS_COMMIT: ${{ github.sha }} | ||||||
|  |  | ||||||
|       - name: Upload Coverage to Codecov |       - name: Upload Coverage to Codecov | ||||||
|         uses: codecov/codecov-action@v3 |         uses: codecov/codecov-action@v4 | ||||||
|         # 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: | ||||||
| @@ -141,7 +185,7 @@ jobs: | |||||||
|       - name: Save snapshots cache |       - name: Save snapshots cache | ||||||
|         id: cache-upload |         id: cache-upload | ||||||
|         if: ${{ github.event_name == 'push' && needs.e2e.result != 'failure' }} |         if: ${{ github.event_name == 'push' && needs.e2e.result != 'failure' }} | ||||||
|         uses: actions/cache/save@v3 |         uses: actions/cache/save@v4 | ||||||
|         with: |         with: | ||||||
|           path: ./snapshots |           path: ./snapshots | ||||||
|           key: ${{ runner.os }}-snapshots-${{ github.event.after }} |           key: ${{ runner.os }}-snapshots-${{ github.event.after }} | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/link-checker.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/link-checker.yml
									
									
									
									
										vendored
									
									
								
							| @@ -29,14 +29,14 @@ jobs: | |||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|       - name: Restore lychee cache |       - name: Restore lychee cache | ||||||
|         uses: actions/cache@v3 |         uses: actions/cache@v4 | ||||||
|         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.1 |         uses: lycheeverse/lychee-action@v1.9.3 | ||||||
|         with: |         with: | ||||||
|           args: >- |           args: >- | ||||||
|             --config .github/lychee.toml |             --config .github/lychee.toml | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							| @@ -16,20 +16,17 @@ permissions: | |||||||
| jobs: | jobs: | ||||||
|   lint: |   lint: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         node-version: [18.x] |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v2 |       - uses: pnpm/action-setup@v2 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js ${{ matrix.node-version }} |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version: ${{ matrix.node-version }} |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Install Packages |       - name: Install Packages | ||||||
|         run: | |         run: | | ||||||
|   | |||||||
							
								
								
									
										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@v5 |         uses: release-drafter/release-drafter@v6 | ||||||
|         with: |         with: | ||||||
|           config-name: pr-labeler.yml |           config-name: pr-labeler.yml | ||||||
|           disable-autolabeler: false |           disable-autolabeler: false | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								.github/workflows/publish-docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/publish-docs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -31,19 +31,19 @@ jobs: | |||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version: 18 |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Install Packages |       - name: Install Packages | ||||||
|         run: pnpm install --frozen-lockfile |         run: pnpm install --frozen-lockfile | ||||||
|  |  | ||||||
|       - name: Setup Pages |       - name: Setup Pages | ||||||
|         uses: actions/configure-pages@v3 |         uses: actions/configure-pages@v4 | ||||||
|  |  | ||||||
|       - 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@v1 |         uses: actions/upload-pages-artifact@v3 | ||||||
|         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@v2 |         uses: actions/deploy-pages@v4 | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/release-draft.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/release-draft.yml
									
									
									
									
										vendored
									
									
								
							| @@ -12,11 +12,11 @@ jobs: | |||||||
|   draft-release: |   draft-release: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     permissions: |     permissions: | ||||||
|       contents: write # write permission is required to create a github release |       contents: write # write permission is required to create a GitHub release | ||||||
|       pull-requests: read # required to read PR titles/labels |       pull-requests: read # required to read PR titles/labels | ||||||
|     steps: |     steps: | ||||||
|       - name: Draft Release |       - name: Draft Release | ||||||
|         uses: release-drafter/release-drafter@v5 |         uses: release-drafter/release-drafter@v6 | ||||||
|         with: |         with: | ||||||
|           disable-autolabeler: true |           disable-autolabeler: true | ||||||
|         env: |         env: | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ jobs: | |||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version: 18.x |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Install Packages |       - name: Install Packages | ||||||
|         run: | |         run: | | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/release-publish.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/release-publish.yml
									
									
									
									
										vendored
									
									
								
							| @@ -14,11 +14,11 @@ jobs: | |||||||
|       - uses: pnpm/action-setup@v2 |       - uses: pnpm/action-setup@v2 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js v18 |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version: 18.x |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Install Packages |       - name: Install Packages | ||||||
|         run: | |         run: | | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,20 +8,17 @@ permissions: | |||||||
| jobs: | jobs: | ||||||
|   unit-test: |   unit-test: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         node-version: [18.x] |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|       - uses: pnpm/action-setup@v2 |       - uses: pnpm/action-setup@v2 | ||||||
|         # uses version from "packageManager" field in package.json |         # uses version from "packageManager" field in package.json | ||||||
|  |  | ||||||
|       - name: Setup Node.js ${{ matrix.node-version }} |       - name: Setup Node.js | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
|         with: |         with: | ||||||
|           cache: pnpm |           cache: pnpm | ||||||
|           node-version: ${{ matrix.node-version }} |           node-version-file: '.node-version' | ||||||
|  |  | ||||||
|       - name: Install Packages |       - name: Install Packages | ||||||
|         run: | |         run: | | ||||||
| @@ -42,7 +39,7 @@ jobs: | |||||||
|           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: Upload Coverage to Codecov |       - name: Upload Coverage to Codecov | ||||||
|         uses: codecov/codecov-action@v3 |         uses: codecov/codecov-action@v4 | ||||||
|         # 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/update-browserlist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/update-browserlist.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,7 +19,7 @@ jobs: | |||||||
|           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@v5 |         uses: peter-evans/create-pull-request@v6 | ||||||
|         with: |         with: | ||||||
|           branch: update-browserslist |           branch: update-browserslist | ||||||
|           title: Update Browserslist |           title: Update Browserslist | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -46,4 +46,8 @@ stats/ | |||||||
|  |  | ||||||
| demos/dev/** | demos/dev/** | ||||||
| !/demos/dev/example.html | !/demos/dev/example.html | ||||||
|  | !/demos/dev/reload.js | ||||||
| tsx-0/** | tsx-0/** | ||||||
|  |  | ||||||
|  | # autogenereated by langium-cli | ||||||
|  | generated/ | ||||||
| @@ -1,4 +0,0 @@ | |||||||
| #!/bin/sh |  | ||||||
| # . "$(dirname "$0")/_/husky.sh" |  | ||||||
|  |  | ||||||
| # npx --no-install commitlint --edit $1 |  | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
| . "$(dirname "$0")/_/husky.sh" | . "$(dirname "$0")/_/husky.sh" | ||||||
|  |  | ||||||
| pnpm run pre-commit | NODE_OPTIONS="--max_old_space_size=8192" pnpm run pre-commit | ||||||
|   | |||||||
| @@ -6,6 +6,6 @@ export default { | |||||||
|     // https://prettier.io/docs/en/cli.html#--cache |     // https://prettier.io/docs/en/cli.html#--cache | ||||||
|     'prettier --write', |     'prettier --write', | ||||||
|   ], |   ], | ||||||
|   'cSpell.json': ['tsx scripts/fixCSpell.ts'], |   '.cspell/*.txt': ['tsx scripts/fixCSpell.ts'], | ||||||
|   '**/*.jison': ['pnpm -w run lint:jison'], |   '**/*.jison': ['pnpm -w run lint:jison'], | ||||||
| }; | }; | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								.node-version
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.node-version
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | 20.12.2 | ||||||
							
								
								
									
										1
									
								
								.npmrc
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								.npmrc
									
									
									
									
									
								
							| @@ -1,3 +1,4 @@ | |||||||
| registry=https://registry.npmjs.org | registry=https://registry.npmjs.org | ||||||
| auto-install-peers=true | auto-install-peers=true | ||||||
| strict-peer-dependencies=false | strict-peer-dependencies=false | ||||||
|  | package-import-method=clone-or-copy | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| dist | dist | ||||||
| cypress/platform/xss3.html | cypress/platform/xss3.html | ||||||
| .cache | .cache | ||||||
|  | .pnpm-store | ||||||
| coverage | coverage | ||||||
| # Autogenerated by PNPM | # Autogenerated by PNPM | ||||||
| pnpm-lock.yaml | pnpm-lock.yaml | ||||||
| @@ -10,6 +11,8 @@ stats | |||||||
| .nyc_output | .nyc_output | ||||||
| # Autogenerated by `pnpm run --filter mermaid types:build-config` | # Autogenerated by `pnpm run --filter mermaid types:build-config` | ||||||
| packages/mermaid/src/config.type.ts | packages/mermaid/src/config.type.ts | ||||||
|  | # autogenereated by langium-cli | ||||||
|  | generated/ | ||||||
| # Ignore the files creates in /demos/dev except for example.html | # Ignore the files creates in /demos/dev except for example.html | ||||||
| demos/dev/** | demos/dev/** | ||||||
| !/demos/dev/example.html | !/demos/dev/example.html | ||||||
| @@ -3,5 +3,6 @@ | |||||||
|   "printWidth": 100, |   "printWidth": 100, | ||||||
|   "singleQuote": true, |   "singleQuote": true, | ||||||
|   "useTabs": false, |   "useTabs": false, | ||||||
|   "tabWidth": 2 |   "tabWidth": 2, | ||||||
|  |   "trailingComma": "es5" | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,11 +3,12 @@ import { resolve } from 'path'; | |||||||
| import { fileURLToPath } from 'url'; | import { fileURLToPath } from 'url'; | ||||||
| import jisonPlugin from './jisonPlugin.js'; | import jisonPlugin from './jisonPlugin.js'; | ||||||
| import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | import jsonSchemaPlugin from './jsonSchemaPlugin.js'; | ||||||
| import { readFileSync } from 'fs'; |  | ||||||
| import typescript from '@rollup/plugin-typescript'; | import typescript from '@rollup/plugin-typescript'; | ||||||
| import { visualizer } from 'rollup-plugin-visualizer'; | import { visualizer } from 'rollup-plugin-visualizer'; | ||||||
| import type { TemplateType } from 'rollup-plugin-visualizer/dist/plugin/template-types.js'; | import type { TemplateType } from 'rollup-plugin-visualizer/dist/plugin/template-types.js'; | ||||||
| import istanbul from 'vite-plugin-istanbul'; | import istanbul from 'vite-plugin-istanbul'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  | import { generateLangium } from '../.build/generateLangium.js'; | ||||||
|  |  | ||||||
| const visualize = process.argv.includes('--visualize'); | const visualize = process.argv.includes('--visualize'); | ||||||
| const watch = process.argv.includes('--watch'); | const watch = process.argv.includes('--watch'); | ||||||
| @@ -36,24 +37,6 @@ const visualizerOptions = (packageName: string, core = false): PluginOption[] => | |||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const packageOptions = { |  | ||||||
|   mermaid: { |  | ||||||
|     name: 'mermaid', |  | ||||||
|     packageName: 'mermaid', |  | ||||||
|     file: 'mermaid.ts', |  | ||||||
|   }, |  | ||||||
|   'mermaid-example-diagram': { |  | ||||||
|     name: 'mermaid-example-diagram', |  | ||||||
|     packageName: 'mermaid-example-diagram', |  | ||||||
|     file: 'detector.ts', |  | ||||||
|   }, |  | ||||||
|   'mermaid-zenuml': { |  | ||||||
|     name: 'mermaid-zenuml', |  | ||||||
|     packageName: 'mermaid-zenuml', |  | ||||||
|     file: 'detector.ts', |  | ||||||
|   }, |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| interface BuildOptions { | interface BuildOptions { | ||||||
|   minify: boolean | 'esbuild'; |   minify: boolean | 'esbuild'; | ||||||
|   core?: boolean; |   core?: boolean; | ||||||
| @@ -72,34 +55,8 @@ export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions) | |||||||
|       sourcemap, |       sourcemap, | ||||||
|       entryFileNames: `${name}.esm${minify ? '.min' : ''}.mjs`, |       entryFileNames: `${name}.esm${minify ? '.min' : ''}.mjs`, | ||||||
|     }, |     }, | ||||||
|     { |  | ||||||
|       name, |  | ||||||
|       format: 'umd', |  | ||||||
|       sourcemap, |  | ||||||
|       entryFileNames: `${name}${minify ? '.min' : ''}.js`, |  | ||||||
|     }, |  | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   if (core) { |  | ||||||
|     const { dependencies } = JSON.parse( |  | ||||||
|       readFileSync(resolve(__dirname, `../packages/${packageName}/package.json`), 'utf-8') |  | ||||||
|     ); |  | ||||||
|     // Core build is used to generate file without bundled dependencies. |  | ||||||
|     // This is used by downstream projects to bundle dependencies themselves. |  | ||||||
|     // Ignore dependencies and any dependencies of dependencies |  | ||||||
|     // Adapted from the RegEx used by `rollup-plugin-node` |  | ||||||
|     external.push(new RegExp('^(?:' + Object.keys(dependencies).join('|') + ')(?:/.+)?$')); |  | ||||||
|     // This needs to be an array. Otherwise vite will build esm & umd with same name and overwrite esm with umd. |  | ||||||
|     output = [ |  | ||||||
|       { |  | ||||||
|         name, |  | ||||||
|         format: 'esm', |  | ||||||
|         sourcemap, |  | ||||||
|         entryFileNames: `${name}.core.mjs`, |  | ||||||
|       }, |  | ||||||
|     ]; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   const config: InlineConfig = { |   const config: InlineConfig = { | ||||||
|     configFile: false, |     configFile: false, | ||||||
|     build: { |     build: { | ||||||
| @@ -129,7 +86,7 @@ export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions) | |||||||
|       // @ts-expect-error According to the type definitions, rollup plugins are incompatible with vite |       // @ts-expect-error According to the type definitions, rollup plugins are incompatible with vite | ||||||
|       typescript({ compilerOptions: { declaration: false } }), |       typescript({ compilerOptions: { declaration: false } }), | ||||||
|       istanbul({ |       istanbul({ | ||||||
|         exclude: ['node_modules', 'test/', '__mocks__'], |         exclude: ['node_modules', 'test/', '__mocks__', 'generated'], | ||||||
|         extension: ['.js', '.ts'], |         extension: ['.js', '.ts'], | ||||||
|         requireEnv: true, |         requireEnv: true, | ||||||
|         forceBuildInstrument: coverage, |         forceBuildInstrument: coverage, | ||||||
| @@ -149,24 +106,28 @@ export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions) | |||||||
|  |  | ||||||
| const buildPackage = async (entryName: keyof typeof packageOptions) => { | const buildPackage = async (entryName: keyof typeof packageOptions) => { | ||||||
|   await build(getBuildConfig({ minify: false, entryName })); |   await build(getBuildConfig({ minify: false, entryName })); | ||||||
|   await build(getBuildConfig({ minify: 'esbuild', entryName })); |  | ||||||
|   await build(getBuildConfig({ minify: false, core: true, entryName })); |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const main = async () => { | const main = async () => { | ||||||
|   const packageNames = Object.keys(packageOptions) as (keyof typeof packageOptions)[]; |   const packageNames = Object.keys(packageOptions) as (keyof typeof packageOptions)[]; | ||||||
|   for (const pkg of packageNames.filter((pkg) => !mermaidOnly || pkg === 'mermaid')) { |   for (const pkg of packageNames.filter( | ||||||
|  |     (pkg) => !mermaidOnly || pkg === 'mermaid' || pkg === 'parser' | ||||||
|  |   )) { | ||||||
|     await buildPackage(pkg); |     await buildPackage(pkg); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | await generateLangium(); | ||||||
|  |  | ||||||
| if (watch) { | if (watch) { | ||||||
|  |   await build(getBuildConfig({ minify: false, watch, core: false, entryName: 'parser' })); | ||||||
|   build(getBuildConfig({ minify: false, watch, core: false, entryName: 'mermaid' })); |   build(getBuildConfig({ minify: false, watch, core: false, entryName: 'mermaid' })); | ||||||
|   if (!mermaidOnly) { |   if (!mermaidOnly) { | ||||||
|     build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-example-diagram' })); |     build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-example-diagram' })); | ||||||
|     build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-zenuml' })); |     build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-zenuml' })); | ||||||
|   } |   } | ||||||
| } else if (visualize) { | } else if (visualize) { | ||||||
|  |   await build(getBuildConfig({ minify: false, watch, core: false, entryName: 'parser' })); | ||||||
|   await build(getBuildConfig({ minify: false, core: true, entryName: 'mermaid' })); |   await build(getBuildConfig({ minify: false, core: true, entryName: 'mermaid' })); | ||||||
|   await build(getBuildConfig({ minify: false, core: false, entryName: 'mermaid' })); |   await build(getBuildConfig({ minify: false, core: false, entryName: 'mermaid' })); | ||||||
| } else { | } else { | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| import { transformJison } from './jisonTransformer.js'; | import { transformJison } from '../.build/jisonTransformer.js'; | ||||||
|  |  | ||||||
| const fileRegex = /\.(jison)$/; | const fileRegex = /\.(jison)$/; | ||||||
|  |  | ||||||
| export default function jison() { | export default function jison() { | ||||||
|   return { |   return { | ||||||
|     name: 'jison', |     name: 'jison', | ||||||
|  |  | ||||||
|     transform(src: string, id: string) { |     transform(src: string, id: string) { | ||||||
|       if (fileRegex.test(id)) { |       if (fileRegex.test(id)) { | ||||||
|         return { |         return { | ||||||
|   | |||||||
| @@ -1,109 +1,5 @@ | |||||||
| import { load, JSON_SCHEMA } from 'js-yaml'; |  | ||||||
| import assert from 'node:assert'; |  | ||||||
| import Ajv2019, { type JSONSchemaType } from 'ajv/dist/2019.js'; |  | ||||||
| import { PluginOption } from 'vite'; | import { PluginOption } from 'vite'; | ||||||
|  | import { getDefaults, getSchema, loadSchema } from '../.build/jsonSchema.js'; | ||||||
| import type { MermaidConfig, BaseDiagramConfig } from '../packages/mermaid/src/config.type.js'; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * All of the keys in the mermaid config that have a mermaid diagram config. |  | ||||||
|  */ |  | ||||||
| const MERMAID_CONFIG_DIAGRAM_KEYS = [ |  | ||||||
|   'flowchart', |  | ||||||
|   'sequence', |  | ||||||
|   'gantt', |  | ||||||
|   'journey', |  | ||||||
|   'class', |  | ||||||
|   'state', |  | ||||||
|   'er', |  | ||||||
|   'pie', |  | ||||||
|   'quadrantChart', |  | ||||||
|   'xyChart', |  | ||||||
|   'requirement', |  | ||||||
|   'mindmap', |  | ||||||
|   'timeline', |  | ||||||
|   'gitGraph', |  | ||||||
|   'c4', |  | ||||||
|   'sankey', |  | ||||||
| ] as const; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Generate default values from the JSON Schema. |  | ||||||
|  * |  | ||||||
|  * AJV does not support nested default values yet (or default values with $ref), |  | ||||||
|  * so we need to manually find them (this may be fixed in ajv v9). |  | ||||||
|  * |  | ||||||
|  * @param mermaidConfigSchema - The Mermaid JSON Schema to use. |  | ||||||
|  * @returns The default mermaid config object. |  | ||||||
|  */ |  | ||||||
| function generateDefaults(mermaidConfigSchema: JSONSchemaType<MermaidConfig>) { |  | ||||||
|   const ajv = new Ajv2019({ |  | ||||||
|     useDefaults: true, |  | ||||||
|     allowUnionTypes: true, |  | ||||||
|     strict: true, |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   ajv.addKeyword({ |  | ||||||
|     keyword: 'meta:enum', // used by jsonschema2md |  | ||||||
|     errors: false, |  | ||||||
|   }); |  | ||||||
|   ajv.addKeyword({ |  | ||||||
|     keyword: 'tsType', // used by json-schema-to-typescript |  | ||||||
|     errors: false, |  | ||||||
|   }); |  | ||||||
|  |  | ||||||
|   // ajv currently doesn't support nested default values, see https://github.com/ajv-validator/ajv/issues/1718 |  | ||||||
|   // (may be fixed in v9) so we need to manually use sub-schemas |  | ||||||
|   const mermaidDefaultConfig = {}; |  | ||||||
|  |  | ||||||
|   assert.ok(mermaidConfigSchema.$defs); |  | ||||||
|   const baseDiagramConfig = mermaidConfigSchema.$defs.BaseDiagramConfig; |  | ||||||
|  |  | ||||||
|   for (const key of MERMAID_CONFIG_DIAGRAM_KEYS) { |  | ||||||
|     const subSchemaRef = mermaidConfigSchema.properties[key].$ref; |  | ||||||
|     const [root, defs, defName] = subSchemaRef.split('/'); |  | ||||||
|     assert.strictEqual(root, '#'); |  | ||||||
|     assert.strictEqual(defs, '$defs'); |  | ||||||
|     const subSchema = { |  | ||||||
|       $schema: mermaidConfigSchema.$schema, |  | ||||||
|       $defs: mermaidConfigSchema.$defs, |  | ||||||
|       ...mermaidConfigSchema.$defs[defName], |  | ||||||
|     } as JSONSchemaType<BaseDiagramConfig>; |  | ||||||
|  |  | ||||||
|     const validate = ajv.compile(subSchema); |  | ||||||
|  |  | ||||||
|     mermaidDefaultConfig[key] = {}; |  | ||||||
|  |  | ||||||
|     for (const required of subSchema.required ?? []) { |  | ||||||
|       if (subSchema.properties[required] === undefined && baseDiagramConfig.properties[required]) { |  | ||||||
|         mermaidDefaultConfig[key][required] = baseDiagramConfig.properties[required].default; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     if (!validate(mermaidDefaultConfig[key])) { |  | ||||||
|       throw new Error( |  | ||||||
|         `schema for subconfig ${key} does not have valid defaults! Errors were ${JSON.stringify( |  | ||||||
|           validate.errors, |  | ||||||
|           undefined, |  | ||||||
|           2 |  | ||||||
|         )}` |  | ||||||
|       ); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   const validate = ajv.compile(mermaidConfigSchema); |  | ||||||
|  |  | ||||||
|   if (!validate(mermaidDefaultConfig)) { |  | ||||||
|     throw new Error( |  | ||||||
|       `Mermaid config JSON Schema does not have valid defaults! Errors were ${JSON.stringify( |  | ||||||
|         validate.errors, |  | ||||||
|         undefined, |  | ||||||
|         2 |  | ||||||
|       )}` |  | ||||||
|     ); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return mermaidDefaultConfig; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Vite plugin that handles JSON Schemas saved as a `.schema.yaml` file. |  * Vite plugin that handles JSON Schemas saved as a `.schema.yaml` file. | ||||||
| @@ -120,32 +16,13 @@ export default function jsonSchemaPlugin(): PluginOption { | |||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       if (idAsUrl.searchParams.get('only-defaults')) { |       const jsonSchema = loadSchema(src, idAsUrl.pathname); | ||||||
|         const jsonSchema = load(src, { |  | ||||||
|           filename: idAsUrl.pathname, |  | ||||||
|           // only allow JSON types in our YAML doc (will probably be default in YAML 1.3) |  | ||||||
|           // e.g. `true` will be parsed a boolean `true`, `True` will be parsed as string `"True"`. |  | ||||||
|           schema: JSON_SCHEMA, |  | ||||||
|         }) as JSONSchemaType<MermaidConfig>; |  | ||||||
|       return { |       return { | ||||||
|           code: `export default ${JSON.stringify(generateDefaults(jsonSchema), undefined, 2)};`, |         code: idAsUrl.searchParams.get('only-defaults') | ||||||
|  |           ? getDefaults(jsonSchema) | ||||||
|  |           : getSchema(jsonSchema), | ||||||
|         map: null, // no source map |         map: null, // no source map | ||||||
|       }; |       }; | ||||||
|       } else { |  | ||||||
|         return { |  | ||||||
|           code: `export default ${JSON.stringify( |  | ||||||
|             load(src, { |  | ||||||
|               filename: idAsUrl.pathname, |  | ||||||
|               // only allow JSON types in our YAML doc (will probably be default in YAML 1.3) |  | ||||||
|               // e.g. `true` will be parsed a boolean `true`, `True` will be parsed as string `"True"`. |  | ||||||
|               schema: JSON_SCHEMA, |  | ||||||
|             }), |  | ||||||
|             undefined, |  | ||||||
|             2 |  | ||||||
|           )};`, |  | ||||||
|           map: null, // provide source map if available |  | ||||||
|         }; |  | ||||||
|       } |  | ||||||
|     }, |     }, | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| import express from 'express'; | import express from 'express'; | ||||||
| import cors from 'cors'; | import cors from 'cors'; | ||||||
| import { createServer as createViteServer } from 'vite'; | import { createServer as createViteServer } from 'vite'; | ||||||
|  | import { packageOptions } from '../.build/common.js'; | ||||||
|  |  | ||||||
| async function createServer() { | async function createServer() { | ||||||
|   const app = express(); |   const app = express(); | ||||||
| @@ -14,9 +15,9 @@ async function createServer() { | |||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   app.use(cors()); |   app.use(cors()); | ||||||
|   app.use(express.static('./packages/mermaid/dist')); |   for (const { packageName } of Object.values(packageOptions)) { | ||||||
|   app.use(express.static('./packages/mermaid-zenuml/dist')); |     app.use(express.static(`./packages/${packageName}/dist`)); | ||||||
|   app.use(express.static('./packages/mermaid-example-diagram/dist')); |   } | ||||||
|   app.use(vite.middlewares); |   app.use(vite.middlewares); | ||||||
|   app.use(express.static('demos')); |   app.use(express.static('demos')); | ||||||
|   app.use(express.static('cypress/platform')); |   app.use(express.static('cypress/platform')); | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							| @@ -2,7 +2,7 @@ | |||||||
|   "recommendations": [ |   "recommendations": [ | ||||||
|     "dbaeumer.vscode-eslint", |     "dbaeumer.vscode-eslint", | ||||||
|     "esbenp.prettier-vscode", |     "esbenp.prettier-vscode", | ||||||
|     "zixuanchen.vitest-explorer", |     "vitest.explorer", | ||||||
|     "luniclynx.bison" |     "luniclynx.bison" | ||||||
|   ] |   ] | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,2 +1,2 @@ | |||||||
| FROM node:18.19.0-alpine3.18 AS base | FROM node:20.12.2-alpine3.19 AS base | ||||||
| RUN wget -qO- https://get.pnpm.io/install.sh | ENV="$HOME/.shrc" SHELL="$(which sh)" sh - | RUN wget -qO- https://get.pnpm.io/install.sh | ENV="$HOME/.shrc" SHELL="$(which sh)" sh - | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								README.md
									
									
									
									
									
								
							| @@ -15,7 +15,7 @@ Generate diagrams from markdown-like text. | |||||||
| <a href="https://mermaid.live/"><b>Live Editor!</b></a> | <a href="https://mermaid.live/"><b>Live Editor!</b></a> | ||||||
| </p> | </p> | ||||||
| <p align="center"> | <p align="center"> | ||||||
|  <a href="https://mermaid.js.org">📖 Documentation</a> | <a href="https://mermaid.js.org/intro/">🚀 Getting Started</a> | <a href="https://www.jsdelivr.com/package/npm/mermaid">🌐 CDN</a> | <a href="https://join.slack.com/t/mermaid-talk/shared_invite/enQtNzc4NDIyNzk4OTAyLWVhYjQxOTI2OTg4YmE1ZmJkY2Y4MTU3ODliYmIwOTY3NDJlYjA0YjIyZTdkMDMyZTUwOGI0NjEzYmEwODcwOTE" title="Slack invite">🙌 Join Us</a> |  <a href="https://mermaid.js.org">📖 Documentation</a> | <a href="https://mermaid.js.org/intro/">🚀 Getting Started</a> | <a href="https://www.jsdelivr.com/package/npm/mermaid">🌐 CDN</a> | <a href="https://discord.gg/AgrbSrBer3" title="Discord invite">🙌 Join Us</a> | ||||||
| </p> | </p> | ||||||
| <p align="center"> | <p align="center"> | ||||||
| <a href="./README.zh-CN.md">简体中文</a> | <a href="./README.zh-CN.md">简体中文</a> | ||||||
| @@ -33,7 +33,7 @@ Try Live Editor previews of future releases: <a href="https://develop.git.mermai | |||||||
| [](https://app.codecov.io/github/mermaid-js/mermaid/tree/develop) | [](https://app.codecov.io/github/mermaid-js/mermaid/tree/develop) | ||||||
| [](https://www.jsdelivr.com/package/npm/mermaid) | [](https://www.jsdelivr.com/package/npm/mermaid) | ||||||
| [](https://www.npmjs.com/package/mermaid) | [](https://www.npmjs.com/package/mermaid) | ||||||
| [](https://join.slack.com/t/mermaid-talk/shared_invite/enQtNzc4NDIyNzk4OTAyLWVhYjQxOTI2OTg4YmE1ZmJkY2Y4MTU3ODliYmIwOTY3NDJlYjA0YjIyZTdkMDMyZTUwOGI0NjEzYmEwODcwOTE) | [](https://discord.gg/AgrbSrBer3) | ||||||
| [](https://twitter.com/mermaidjs_) | [](https://twitter.com/mermaidjs_) | ||||||
|  |  | ||||||
| <img src="./img/header.png" alt="" /> | <img src="./img/header.png" alt="" /> | ||||||
| @@ -42,7 +42,7 @@ Try Live Editor previews of future releases: <a href="https://develop.git.mermai | |||||||
|  |  | ||||||
| **Thanks to all involved, people committing pull requests, people answering questions! 🙏** | **Thanks to all involved, people committing pull requests, people answering questions! 🙏** | ||||||
|  |  | ||||||
| <a href="https://mermaid-js.github.io/mermaid/landing/"><img src="https://github.com/mermaid-js/mermaid/blob/master/docs/intro/img/book-banner-post-release.jpg" alt="Explore Mermaid.js in depth, with real-world examples, tips & tricks from the creator... The first official book on Mermaid is available for purchase. Check it out!"></a> | <a href="https://mermaid.js.org/landing/"><img src="https://github.com/mermaid-js/mermaid/blob/master/docs/intro/img/book-banner-post-release.jpg" alt="Explore Mermaid.js in depth, with real-world examples, tips & tricks from the creator... The first official book on Mermaid is available for purchase. Check it out!"></a> | ||||||
|  |  | ||||||
| ## Table of content | ## Table of content | ||||||
|  |  | ||||||
| @@ -53,7 +53,7 @@ Try Live Editor previews of future releases: <a href="https://develop.git.mermai | |||||||
| - [Examples](#examples) | - [Examples](#examples) | ||||||
| - [Release](#release) | - [Release](#release) | ||||||
| - [Related projects](#related-projects) | - [Related projects](#related-projects) | ||||||
| - [Contributors](#contributors) | - [Contributors](#contributors---) | ||||||
| - [Security and safe diagrams](#security-and-safe-diagrams) | - [Security and safe diagrams](#security-and-safe-diagrams) | ||||||
| - [Reporting vulnerabilities](#reporting-vulnerabilities) | - [Reporting vulnerabilities](#reporting-vulnerabilities) | ||||||
| - [Appreciation](#appreciation) | - [Appreciation](#appreciation) | ||||||
| @@ -74,12 +74,12 @@ Mermaid addresses this problem by enabling users to create easily modifiable dia | |||||||
| <br/> | <br/> | ||||||
|  |  | ||||||
| Mermaid allows even non-programmers to easily create detailed diagrams through the [Mermaid Live Editor](https://mermaid.live/).<br/> | Mermaid allows even non-programmers to easily create detailed diagrams through the [Mermaid Live Editor](https://mermaid.live/).<br/> | ||||||
| For video tutorials, visit our [Tutorials](./docs/ecosystem/tutorials.md) page. | For video tutorials, visit our [Tutorials](https://mermaid.js.org/ecosystem/tutorials.html) page. | ||||||
| Use Mermaid with your favorite applications, check out the list of [Integrations and Usages of Mermaid](./docs/ecosystem/integrations-community.md). | Use Mermaid with your favorite applications, check out the list of [Integrations and Usages of Mermaid](https://mermaid.js.org/ecosystem/integrations-community.html). | ||||||
|  |  | ||||||
| You can also use Mermaid within [GitHub](https://github.blog/2022-02-14-include-diagrams-markdown-files-mermaid/) as well many of your other favorite applications—check out the list of [Integrations and Usages of Mermaid](./docs/ecosystem/integrations-community.md). | You can also use Mermaid within [GitHub](https://github.blog/2022-02-14-include-diagrams-markdown-files-mermaid/) as well many of your other favorite applications—check out the list of [Integrations and Usages of Mermaid](https://mermaid.js.org/ecosystem/integrations-community.html). | ||||||
|  |  | ||||||
| For a more detailed introduction to Mermaid and some of its more basic uses, look to the [Beginner's Guide](./docs/intro/getting-started.md), [Usage](./docs/config/usage.md) and [Tutorials](./docs/ecosystem/tutorials.md). | 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). | ||||||
|  |  | ||||||
| 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. | ||||||
|  |  | ||||||
| @@ -91,11 +91,11 @@ In our release process we rely heavily on visual regression tests using [applito | |||||||
|  |  | ||||||
| ## 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.github.io/mermaid/#/n00b-syntaxReference).** | **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).** | ||||||
|  |  | ||||||
| <!-- <Flowchart> --> | <!-- <Flowchart> --> | ||||||
|  |  | ||||||
| ### Flowchart [<a href="https://mermaid-js.github.io/mermaid/#/flowchart">docs</a> - <a href="https://mermaid.live/edit#pako:eNpNkMtqwzAQRX9FzKqFJK7t1km8KDQP6KJQSLOLvZhIY1tgS0GWmgbb_165IaFaiXvOFTPqgGtBkEJR6zOv0Fj2scsU8-ft8I5G5Gw6fe339GN7tnrYaafE45WvRsLW3Ya4bKVWwzVe_xU-FfVsc9hR62rLwvw_2591z7Y3FuUwgYZMg1L4ObrRzMBW1FAGqb8KKtCLGWRq8Ko7CbS0FdJqA2mBdUsTQGf110VxSK1xdJM2EkuDzd2qNQrypQ7s5TQuXcrW-ie5VoUsx9yZ2seVtac2DYIRz0ppK3eccd0ErRTjD1XfyyRIomSBUUzJPMaXOBb8GC4XRfQcFmL-FEYIwzD8AggvcHE">live editor</a>] | ### Flowchart [<a href="https://mermaid.js.org/syntax/flowchart.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNpNkMtqwzAQRX9FzKqFJK7t1km8KDQP6KJQSLOLvZhIY1tgS0GWmgbb_165IaFaiXvOFTPqgGtBkEJR6zOv0Fj2scsU8-ft8I5G5Gw6fe339GN7tnrYaafE45WvRsLW3Ya4bKVWwzVe_xU-FfVsc9hR62rLwvw_2591z7Y3FuUwgYZMg1L4ObrRzMBW1FAGqb8KKtCLGWRq8Ko7CbS0FdJqA2mBdUsTQGf110VxSK1xdJM2EkuDzd2qNQrypQ7s5TQuXcrW-ie5VoUsx9yZ2seVtac2DYIRz0ppK3eccd0ErRTjD1XfyyRIomSBUUzJPMaXOBb8GC4XRfQcFmL-FEYIwzD8AggvcHE">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| flowchart LR | flowchart LR | ||||||
| @@ -115,12 +115,12 @@ C -->|One| D[Result 1] | |||||||
| C -->|Two| E[Result 2] | C -->|Two| E[Result 2] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Sequence diagram [<a href="https://mermaid-js.github.io/mermaid/#/sequenceDiagram">docs</a> - <a href="https://mermaid.live/edit#pako:eNo9kMluwjAQhl_F-AykQMuSA1WrbuLQQ3v1ZbAnsVXHkzrjVhHi3etQwKfRv4w-z0FqMihL2eF3wqDxyUEdoVHhwTuNk-12RzaU4g29JzHMY2HpV0BE0VO6V8ETtdkGz1Zb1F8qiPyG5LX84mrLAmpwoWNh-5a0pWCiAxUwGBXeiVHEU4oq8V_6AHYUwAu2lLLTjVQ4bc1rT2yleI0IfJG320faZ9ABbk-Jz3hZnFxBduR9L2oiM5Jj2WBswJn8-cMArSRbbFDJMo8GK0ielVThmKOpNcD4bBxTlGUFvsOxhMT02QctS44JL6HzAS-iJzCYOwfJfTscunYd542aQuXqQU_RZ9kyt11ZFIM9rR3btJ9qaorOGQuR7c9mWSznyzXMF7hcLeBusTB6P9usq_ntrDKrm9kc5PF4_AMJE56Z">live editor</a>] | ### Sequence diagram [<a href="https://mermaid.js.org/syntax/sequenceDiagram.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNo9kMluwjAQhl_F-AykQMuSA1WrbuLQQ3v1ZbAnsVXHkzrjVhHi3etQwKfRv4w-z0FqMihL2eF3wqDxyUEdoVHhwTuNk-12RzaU4g29JzHMY2HpV0BE0VO6V8ETtdkGz1Zb1F8qiPyG5LX84mrLAmpwoWNh-5a0pWCiAxUwGBXeiVHEU4oq8V_6AHYUwAu2lLLTjVQ4bc1rT2yleI0IfJG320faZ9ABbk-Jz3hZnFxBduR9L2oiM5Jj2WBswJn8-cMArSRbbFDJMo8GK0ielVThmKOpNcD4bBxTlGUFvsOxhMT02QctS44JL6HzAS-iJzCYOwfJfTscunYd542aQuXqQU_RZ9kyt11ZFIM9rR3btJ9qaorOGQuR7c9mWSznyzXMF7hcLeBusTB6P9usq_ntrDKrm9kc5PF4_AMJE56Z">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| sequenceDiagram | sequenceDiagram | ||||||
| Alice->>John: Hello John, how are you? | Alice->>John: Hello John, how are you? | ||||||
| loop Healthcheck | loop HealthCheck | ||||||
|     John->>John: Fight against hypochondria |     John->>John: Fight against hypochondria | ||||||
| end | end | ||||||
| Note right of John: Rational thoughts! | Note right of John: Rational thoughts! | ||||||
| @@ -132,7 +132,7 @@ Bob-->>John: Jolly good! | |||||||
| ```mermaid | ```mermaid | ||||||
| sequenceDiagram | sequenceDiagram | ||||||
| Alice->>John: Hello John, how are you? | Alice->>John: Hello John, how are you? | ||||||
| loop Healthcheck | loop HealthCheck | ||||||
|     John->>John: Fight against hypochondria |     John->>John: Fight against hypochondria | ||||||
| end | end | ||||||
| Note right of John: Rational thoughts! | Note right of John: Rational thoughts! | ||||||
| @@ -141,7 +141,7 @@ John->>Bob: How about you? | |||||||
| Bob-->>John: Jolly good! | Bob-->>John: Jolly good! | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Gantt chart [<a href="https://mermaid-js.github.io/mermaid/#/gantt">docs</a> - <a href="https://mermaid.live/edit#pako:eNp90cGOgyAQBuBXIZxtFbG29bbZ3fsmvXKZylhJEAyOTZrGd1_sto3xsHMBhu-HBO689hp5xS_giJQbsCbjHTv9jcp9-q63SKhZpb3DhMXSOIiE5ZkoNpnYZGXynh6U-4jBK7JnVfBYJo9QvgjtEya1cj8QwFq0TMz4lZqxTBg0hOF5m1jifI2Lf7Bc490CyxUu1rhc4GLGPOEdhg6Mjq92V44xxanFDhWv4lRjA6MlxZWbIh17DYTf2pAPvGrADphwGMmfbq7mFYURX-jLwCVA91bWg8YYunO69Y8vMgPFI2vvGnOZ-2Owsd0S9UOVpvP29mKoHc_b2nfpYHQLgdrrsUzLvDxALrHcS9hJqeuzOB6avBCN3mciBz5N0y_wxZ0J">live editor</a>] | ### Gantt chart [<a href="https://mermaid.js.org/syntax/gantt.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNp90cGOgyAQBuBXIZxtFbG29bbZ3fsmvXKZylhJEAyOTZrGd1_sto3xsHMBhu-HBO689hp5xS_giJQbsCbjHTv9jcp9-q63SKhZpb3DhMXSOIiE5ZkoNpnYZGXynh6U-4jBK7JnVfBYJo9QvgjtEya1cj8QwFq0TMz4lZqxTBg0hOF5m1jifI2Lf7Bc490CyxUu1rhc4GLGPOEdhg6Mjq92V44xxanFDhWv4lRjA6MlxZWbIh17DYTf2pAPvGrADphwGMmfbq7mFYURX-jLwCVA91bWg8YYunO69Y8vMgPFI2vvGnOZ-2Owsd0S9UOVpvP29mKoHc_b2nfpYHQLgdrrsUzLvDxALrHcS9hJqeuzOB6avBCN3mciBz5N0y_wxZ0J">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| gantt | gantt | ||||||
| @@ -165,7 +165,7 @@ gantt | |||||||
|     Parallel 4   :         des6, after des4, 1d |     Parallel 4   :         des6, after des4, 1d | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Class diagram [<a href="https://mermaid-js.github.io/mermaid/#/classDiagram">docs</a> - <a href="https://mermaid.live/edit#pako:eNpdkTFPwzAQhf-K5QlQ2zQJJG1UBaGWDYmBgYEwXO1LYuTEwXYqlZL_jt02asXm--690zvfgTLFkWaUSTBmI6DS0BTt2lfzkKx-p1PytEO9f1FtdaQkI2ulZNGuVqK1qEtgmOfk7BitSzKdOhg59XuNGgk0RDxed-_IOr6uf8cZ6UhTZ8bvHqS5ub1mr9svZPbjk6DEBlu7AQuXyBkx4gcvDk9cUMJq0XT_YaW0kNK5j-ufAoRzcihaQvLcoN4Jv50vvVxw_xrnD3RCG9QNCO4-8OgpqK1dpoJm7smxhF7agp6kfcfB4jMXVmmalW4tnFDorXrbt4xmVvc4is53GKFUwNF5DtTuO3-sShjrJjLVlqLyvNfS4drazmRB4NuzSti6386YagIjeA3a1rtlEiRRsoAoxiSN4SGOOduGy0UZ3YclT-dhBHQYhj8dc6_I">live editor</a>] | ### Class diagram [<a href="https://mermaid.js.org/syntax/classDiagram.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNpdkTFPwzAQhf-K5QlQ2zQJJG1UBaGWDYmBgYEwXO1LYuTEwXYqlZL_jt02asXm--690zvfgTLFkWaUSTBmI6DS0BTt2lfzkKx-p1PytEO9f1FtdaQkI2ulZNGuVqK1qEtgmOfk7BitSzKdOhg59XuNGgk0RDxed-_IOr6uf8cZ6UhTZ8bvHqS5ub1mr9svZPbjk6DEBlu7AQuXyBkx4gcvDk9cUMJq0XT_YaW0kNK5j-ufAoRzcihaQvLcoN4Jv50vvVxw_xrnD3RCG9QNCO4-8OgpqK1dpoJm7smxhF7agp6kfcfB4jMXVmmalW4tnFDorXrbt4xmVvc4is53GKFUwNF5DtTuO3-sShjrJjLVlqLyvNfS4drazmRB4NuzSti6386YagIjeA3a1rtlEiRRsoAoxiSN4SGOOduGy0UZ3YclT-dhBHQYhj8dc6_I">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| classDiagram | classDiagram | ||||||
| @@ -207,7 +207,7 @@ class Class10 { | |||||||
|  |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### State diagram [<a href="https://mermaid-js.github.io/mermaid/#/stateDiagram">docs</a> - <a href="https://mermaid.live/edit#pako:eNpdkEFvgzAMhf8K8nEqpYSNthx22Xbcqcexg0sCiZQQlDhIFeK_L8A6TfXp6fOz9ewJGssFVOAJSbwr7ByadGR1n8T6evpO0vQ1uZDSekOrXGFsPqJPO6q-2-imH8f_0TeHXm50lfelsAMjnEHFY6xpMdRAUhhRQxUlFy0GTTXU_RytYeAx-AdXZB1ULWovdoCB7OXWN1CRC-Ju-r3uz6UtchGHJqDbsPygU57iysb2reoWHpyOWBINvsqypb3vFMlw3TfWZF5xiY7keC6zkpUnZIUojwW-FAVvrvn51LLnvOXHQ84Q5nn-AVtLcwk">live editor</a>] | ### State diagram [<a href="https://mermaid.js.org/syntax/stateDiagram.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNpdkEFvgzAMhf8K8nEqpYSNthx22Xbcqcexg0sCiZQQlDhIFeK_L8A6TfXp6fOz9ewJGssFVOAJSbwr7ByadGR1n8T6evpO0vQ1uZDSekOrXGFsPqJPO6q-2-imH8f_0TeHXm50lfelsAMjnEHFY6xpMdRAUhhRQxUlFy0GTTXU_RytYeAx-AdXZB1ULWovdoCB7OXWN1CRC-Ju-r3uz6UtchGHJqDbsPygU57iysb2reoWHpyOWBINvsqypb3vFMlw3TfWZF5xiY7keC6zkpUnZIUojwW-FAVvrvn51LLnvOXHQ84Q5nn-AVtLcwk">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| stateDiagram-v2 | stateDiagram-v2 | ||||||
| @@ -229,7 +229,7 @@ Moving --> Crash | |||||||
| Crash --> [*] | Crash --> [*] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Pie chart [<a href="https://mermaid-js.github.io/mermaid/#/pie">docs</a> - <a href="https://mermaid.live/edit#pako:eNo9jsFugzAMhl8F-VzBgEEh13Uv0F1zcYkTIpEEBadShXj3BU3dzf_n77e8wxQUgYDVkvQSbsFsEgpRtEN_5i_kvzx05XiC-xvUHVzAUXRoVe7v0heFBJ7JkQSRR0Ua08ISpD-ymlaFTN_KcoggNC4bXQATh5-Xn0BwTPSWbhZNRPdvLQEV5dIO_FrPZ43dOJ-cgtfWnDzFJeOZed1EVZ3r0lie06Ocgqs2q2aMPD_HvuqbfsCmpf7aYte2anrU46Cbz1qr60fdIBzH8QvW9lkl">live editor</a>] | ### Pie chart [<a href="https://mermaid.js.org/syntax/pie.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNo9jsFugzAMhl8F-VzBgEEh13Uv0F1zcYkTIpEEBadShXj3BU3dzf_n77e8wxQUgYDVkvQSbsFsEgpRtEN_5i_kvzx05XiC-xvUHVzAUXRoVe7v0heFBJ7JkQSRR0Ua08ISpD-ymlaFTN_KcoggNC4bXQATh5-Xn0BwTPSWbhZNRPdvLQEV5dIO_FrPZ43dOJ-cgtfWnDzFJeOZed1EVZ3r0lie06Ocgqs2q2aMPD_HvuqbfsCmpf7aYte2anrU46Cbz1qr60fdIBzH8QvW9lkl">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| pie | pie | ||||||
| @@ -247,7 +247,7 @@ 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>] | ||||||
|  |  | ||||||
| ### Bar chart (using gantt chart) [<a href="https://mermaid-js.github.io/mermaid/#/gantt">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>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| gantt | gantt | ||||||
| @@ -285,7 +285,7 @@ gantt | |||||||
|     5    : 0, 5 |     5    : 0, 5 | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### User Journey diagram [<a href="https://mermaid-js.github.io/mermaid/#/user-journey">docs</a> - <a href="https://mermaid.live/edit#pako:eNplkMFuwjAQRH9l5TMiTVIC-FqqnjhxzWWJN4khsSN7XRSh_HsdKBVt97R6Mzsj-yoqq0hIAXCywRkaSwNxWHNHsB_hYt1ZmwYUfiueKtbWwIcFtjf5zgH2eCZgQgkrCXt64GgMg2fUzkvIn5Xd_V5COtMFvCH_62ht_5yk7MU8sn61HDTfxD8VYiF6cj1qFd94nWkpuKWYKWRcFdUYOi5FaaZoDYNCpnel2Toha-w8LQQGtofRVEKyC_Qw7TQ2DvsfV2dRUTy6Ch6H-UMb7TlGVtbUupl5cF3ELfPgZZLM8rLR3IbjsrJ94rVq0XH7uS2SIis2mOVUrHNc5bmqjul2U2evaa3WL2mGYpqmL2BGiho">live editor</a>] | ### User Journey diagram [<a href="https://mermaid.js.org/syntax/userJourney.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNplkMFuwjAQRH9l5TMiTVIC-FqqnjhxzWWJN4khsSN7XRSh_HsdKBVt97R6Mzsj-yoqq0hIAXCywRkaSwNxWHNHsB_hYt1ZmwYUfiueKtbWwIcFtjf5zgH2eCZgQgkrCXt64GgMg2fUzkvIn5Xd_V5COtMFvCH_62ht_5yk7MU8sn61HDTfxD8VYiF6cj1qFd94nWkpuKWYKWRcFdUYOi5FaaZoDYNCpnel2Toha-w8LQQGtofRVEKyC_Qw7TQ2DvsfV2dRUTy6Ch6H-UMb7TlGVtbUupl5cF3ELfPgZZLM8rLR3IbjsrJ94rVq0XH7uS2SIis2mOVUrHNc5bmqjul2U2evaa3WL2mGYpqmL2BGiho">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|   journey |   journey | ||||||
| @@ -311,7 +311,7 @@ gantt | |||||||
|       Sit down: 3: Me |       Sit down: 3: Me | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### C4 diagram [<a href="https://mermaid-js.github.io/mermaid/#/c4c">docs</a>] | ### C4 diagram [<a href="https://mermaid.js.org/syntax/c4.html">docs</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| C4Context | C4Context | ||||||
| @@ -405,7 +405,7 @@ The above command generates files into the `dist` folder and publishes them to < | |||||||
|  |  | ||||||
| Mermaid is a growing community and is always accepting new contributors. There's a lot of different ways to help out and we're always looking for extra hands! Look at [this issue](https://github.com/mermaid-js/mermaid/issues/866) if you want to know where to start helping out. | Mermaid is a growing community and is always accepting new contributors. There's a lot of different ways to help out and we're always looking for extra hands! Look at [this issue](https://github.com/mermaid-js/mermaid/issues/866) if you want to know where to start helping out. | ||||||
|  |  | ||||||
| Detailed information about how to contribute can be found in the [contribution guide](CONTRIBUTING.md) | Detailed information about how to contribute can be found in the [contribution guide](https://mermaid.js.org/community/contributing.html) | ||||||
|  |  | ||||||
| ## Security and safe diagrams | ## Security and safe diagrams | ||||||
|  |  | ||||||
|   | |||||||
| @@ -15,7 +15,7 @@ Mermaid | |||||||
| <a href="https://mermaid.live/"><b>实时编辑器!</b></a> | <a href="https://mermaid.live/"><b>实时编辑器!</b></a> | ||||||
| </p> | </p> | ||||||
| <p align="center"> | <p align="center"> | ||||||
|  <a href="https://mermaid.js.org">📖 文档</a> | <a href="https://mermaid.js.org/intro/">🚀 入门</a> | <a href="https://www.jsdelivr.com/package/npm/mermaid">🌐 CDN</a> | <a href="https://join.slack.com/t/mermaid-talk/shared_invite/enQtNzc4NDIyNzk4OTAyLWVhYjQxOTI2OTg4YmE1ZmJkY2Y4MTU3ODliYmIwOTY3NDJlYjA0YjIyZTdkMDMyZTUwOGI0NjEzYmEwODcwOTE" title="Slack invite">🙌 加入我们</a> |  <a href="https://mermaid.js.org">📖 文档</a> | <a href="https://mermaid.js.org/intro/">🚀 入门</a> | <a href="https://www.jsdelivr.com/package/npm/mermaid">🌐 CDN</a> | <a href="https://discord.gg/AgrbSrBer3" title="Discord invite">🙌 加入我们</a> | ||||||
| </p> | </p> | ||||||
| <p align="center"> | <p align="center"> | ||||||
| <a href="./README.md">English</a> | <a href="./README.md">English</a> | ||||||
| @@ -34,7 +34,7 @@ Mermaid | |||||||
| [](https://app.codecov.io/github/mermaid-js/mermaid/tree/develop) | [](https://app.codecov.io/github/mermaid-js/mermaid/tree/develop) | ||||||
| [](https://www.jsdelivr.com/package/npm/mermaid) | [](https://www.jsdelivr.com/package/npm/mermaid) | ||||||
| [](https://www.npmjs.com/package/mermaid) | [](https://www.npmjs.com/package/mermaid) | ||||||
| [](https://join.slack.com/t/mermaid-talk/shared_invite/enQtNzc4NDIyNzk4OTAyLWVhYjQxOTI2OTg4YmE1ZmJkY2Y4MTU3ODliYmIwOTY3NDJlYjA0YjIyZTdkMDMyZTUwOGI0NjEzYmEwODcwOTE) | [](https://discord.gg/AgrbSrBer3) | ||||||
| [](https://twitter.com/mermaidjs_) | [](https://twitter.com/mermaidjs_) | ||||||
|  |  | ||||||
| <img src="./img/header.png" alt="" /> | <img src="./img/header.png" alt="" /> | ||||||
| @@ -43,7 +43,7 @@ Mermaid | |||||||
|  |  | ||||||
| **感谢所有参与进来提交 PR,解答疑问的人们! 🙏** | **感谢所有参与进来提交 PR,解答疑问的人们! 🙏** | ||||||
|  |  | ||||||
| <a href="https://mermaid-js.github.io/mermaid/landing/"><img src="https://github.com/mermaid-js/mermaid/blob/master/docs/intro/img/book-banner-post-release.jpg" alt="Explore Mermaid.js in depth, with real-world examples, tips & tricks from the creator... The first official book on Mermaid is available for purchase. Check it out!"></a> | <a href="https://mermaid.js.org/landing/"><img src="https://github.com/mermaid-js/mermaid/blob/master/docs/intro/img/book-banner-post-release.jpg" alt="Explore Mermaid.js in depth, with real-world examples, tips & tricks from the creator... The first official book on Mermaid is available for purchase. Check it out!"></a> | ||||||
|  |  | ||||||
| ## 关于 Mermaid | ## 关于 Mermaid | ||||||
|  |  | ||||||
| @@ -57,20 +57,20 @@ Mermaid 是一个基于 Javascript 的图表绘制工具,通过解析类 Markd | |||||||
| Mermaid 通过允许用户创建便于修改的图表来解决这一难题,它也可以作为生产脚本(或其他代码)的一部分。<br/> | Mermaid 通过允许用户创建便于修改的图表来解决这一难题,它也可以作为生产脚本(或其他代码)的一部分。<br/> | ||||||
| <br/> | <br/> | ||||||
| Mermaid 甚至能让非程序员也能通过 [Mermaid Live Editor](https://mermaid.live/) 轻松创建详细的图表。<br/> | Mermaid 甚至能让非程序员也能通过 [Mermaid Live Editor](https://mermaid.live/) 轻松创建详细的图表。<br/> | ||||||
| 你可以访问 [教程](./docs/ecosystem/tutorials.md) 来查看 Live Editor 的视频教程,也可以查看 [Mermaid 的集成和使用](./docs/ecosystem/integrations-community.md) 这个清单来检查你的文档工具是否已经集成了 Mermaid 支持。 | 你可以访问 [教程](https://mermaid.js.org/ecosystem/tutorials.html) 来查看 Live Editor 的视频教程,也可以查看 [Mermaid 的集成和使用](https://mermaid.js.org/ecosystem/integrations-community.html) 这个清单来检查你的文档工具是否已经集成了 Mermaid 支持。 | ||||||
|  |  | ||||||
| 如果想要查看关于 Mermaid 更详细的介绍及基础使用方式,可以查看 [入门指引](./docs/intro/getting-started.md), [用法](./docs/config/usage.md) 和 [教程](./docs/ecosystem/tutorials.md). | 如果想要查看关于 Mermaid 更详细的介绍及基础使用方式,可以查看 [入门指引](https://mermaid.js.org/intro/getting-started.html), [用法](https://mermaid.js.org/config/usage.html) 和 [教程](https://mermaid.js.org/ecosystem/tutorials.html). | ||||||
|  |  | ||||||
| <!-- </Main description> --> | <!-- </Main description> --> | ||||||
|  |  | ||||||
| ## 示例 | ## 示例 | ||||||
|  |  | ||||||
| **下面是一些可以使用 Mermaid 创建的图表示例。点击 [语法](https://mermaid-js.github.io/mermaid/#/n00b-syntaxReference) 查看详情。** | **下面是一些可以使用 Mermaid 创建的图表示例。点击 [语法](https://mermaid.js.org/intro/syntax-reference.html) 查看详情。** | ||||||
|  |  | ||||||
| <table> | <table> | ||||||
| <!-- <Flowchart> --> | <!-- <Flowchart> --> | ||||||
|  |  | ||||||
| ### 流程图 [<a href="https://mermaid-js.github.io/mermaid/#/flowchart">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiZ3JhcGggVERcbiAgICBBW0hhcmRdIC0tPnxUZXh0fCBCKFJvdW5kKVxuICAgIEIgLS0-IEN7RGVjaXNpb259XG4gICAgQyAtLT58T25lfCBEW1Jlc3VsdCAxXVxuICAgIEMgLS0-fFR3b3wgRVtSZXN1bHQgMl0iLCJtZXJtYWlkIjp7InRoZW1lIjoiZGVmYXVsdCJ9fQ">live editor</a>] | ### 流程图 [<a href="https://mermaid.js.org/syntax/flowchart.html">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiZ3JhcGggVERcbiAgICBBW0hhcmRdIC0tPnxUZXh0fCBCKFJvdW5kKVxuICAgIEIgLS0-IEN7RGVjaXNpb259XG4gICAgQyAtLT58T25lfCBEW1Jlc3VsdCAxXVxuICAgIEMgLS0-fFR3b3wgRVtSZXN1bHQgMl0iLCJtZXJtYWlkIjp7InRoZW1lIjoiZGVmYXVsdCJ9fQ">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| flowchart LR | flowchart LR | ||||||
| @@ -88,12 +88,12 @@ C -->|One| D[Result 1] | |||||||
| C -->|Two| E[Result 2] | C -->|Two| E[Result 2] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### 时序图 [<a href="https://mermaid-js.github.io/mermaid/#/sequenceDiagram">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoic2VxdWVuY2VEaWFncmFtXG5BbGljZS0-PkpvaG46IEhlbGxvIEpvaG4sIGhvdyBhcmUgeW91P1xubG9vcCBIZWFsdGhjaGVja1xuICAgIEpvaG4tPj5Kb2huOiBGaWdodCBhZ2FpbnN0IGh5cG9jaG9uZHJpYVxuZW5kXG5Ob3RlIHJpZ2h0IG9mIEpvaG46IFJhdGlvbmFsIHRob3VnaHRzIVxuSm9obi0tPj5BbGljZTogR3JlYXQhXG5Kb2huLT4-Qm9iOiBIb3cgYWJvdXQgeW91P1xuQm9iLS0-PkpvaG46IEpvbGx5IGdvb2QhIiwibWVybWFpZCI6eyJ0aGVtZSI6ImRlZmF1bHQifX0">live editor</a>] | ### 时序图 [<a href="https://mermaid.js.org/syntax/sequenceDiagram.html">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoic2VxdWVuY2VEaWFncmFtXG5BbGljZS0-PkpvaG46IEhlbGxvIEpvaG4sIGhvdyBhcmUgeW91P1xubG9vcCBIZWFsdGhjaGVja1xuICAgIEpvaG4tPj5Kb2huOiBGaWdodCBhZ2FpbnN0IGh5cG9jaG9uZHJpYVxuZW5kXG5Ob3RlIHJpZ2h0IG9mIEpvaG46IFJhdGlvbmFsIHRob3VnaHRzIVxuSm9obi0tPj5BbGljZTogR3JlYXQhXG5Kb2huLT4-Qm9iOiBIb3cgYWJvdXQgeW91P1xuQm9iLS0-PkpvaG46IEpvbGx5IGdvb2QhIiwibWVybWFpZCI6eyJ0aGVtZSI6ImRlZmF1bHQifX0">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| sequenceDiagram | sequenceDiagram | ||||||
| Alice->>John: Hello John, how are you? | Alice->>John: Hello John, how are you? | ||||||
| loop Healthcheck | loop HealthCheck | ||||||
|     John->>John: Fight against hypochondria |     John->>John: Fight against hypochondria | ||||||
| end | end | ||||||
| Note right of John: Rational thoughts! | Note right of John: Rational thoughts! | ||||||
| @@ -105,7 +105,7 @@ Bob-->>John: Jolly good! | |||||||
| ```mermaid | ```mermaid | ||||||
| sequenceDiagram | sequenceDiagram | ||||||
| Alice->>John: Hello John, how are you? | Alice->>John: Hello John, how are you? | ||||||
| loop Healthcheck | loop HealthCheck | ||||||
|     John->>John: Fight against hypochondria |     John->>John: Fight against hypochondria | ||||||
| end | end | ||||||
| Note right of John: Rational thoughts! | Note right of John: Rational thoughts! | ||||||
| @@ -114,7 +114,7 @@ John->>Bob: How about you? | |||||||
| Bob-->>John: Jolly good! | Bob-->>John: Jolly good! | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### 甘特图 [<a href="https://mermaid-js.github.io/mermaid/#/gantt">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiZ2FudHRcbnNlY3Rpb24gU2VjdGlvblxuQ29tcGxldGVkIDpkb25lLCAgICBkZXMxLCAyMDE0LTAxLTA2LDIwMTQtMDEtMDhcbkFjdGl2ZSAgICAgICAgOmFjdGl2ZSwgIGRlczIsIDIwMTQtMDEtMDcsIDNkXG5QYXJhbGxlbCAxICAgOiAgICAgICAgIGRlczMsIGFmdGVyIGRlczEsIDFkXG5QYXJhbGxlbCAyICAgOiAgICAgICAgIGRlczQsIGFmdGVyIGRlczEsIDFkXG5QYXJhbGxlbCAzICAgOiAgICAgICAgIGRlczUsIGFmdGVyIGRlczMsIDFkXG5QYXJhbGxlbCA0ICAgOiAgICAgICAgIGRlczYsIGFmdGVyIGRlczQsIDFkIiwibWVybWFpZCI6eyJ0aGVtZSI6ImRlZmF1bHQifX0">live editor</a>] | ### 甘特图 [<a href="https://mermaid.js.org/syntax/gantt.html">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiZ2FudHRcbnNlY3Rpb24gU2VjdGlvblxuQ29tcGxldGVkIDpkb25lLCAgICBkZXMxLCAyMDE0LTAxLTA2LDIwMTQtMDEtMDhcbkFjdGl2ZSAgICAgICAgOmFjdGl2ZSwgIGRlczIsIDIwMTQtMDEtMDcsIDNkXG5QYXJhbGxlbCAxICAgOiAgICAgICAgIGRlczMsIGFmdGVyIGRlczEsIDFkXG5QYXJhbGxlbCAyICAgOiAgICAgICAgIGRlczQsIGFmdGVyIGRlczEsIDFkXG5QYXJhbGxlbCAzICAgOiAgICAgICAgIGRlczUsIGFmdGVyIGRlczMsIDFkXG5QYXJhbGxlbCA0ICAgOiAgICAgICAgIGRlczYsIGFmdGVyIGRlczQsIDFkIiwibWVybWFpZCI6eyJ0aGVtZSI6ImRlZmF1bHQifX0">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| gantt | gantt | ||||||
| @@ -138,7 +138,7 @@ gantt | |||||||
|     Parallel 4   :         des6, after des4, 1d |     Parallel 4   :         des6, after des4, 1d | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### 类图 [<a href="https://mermaid-js.github.io/mermaid/#/classDiagram">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiY2xhc3NEaWFncmFtXG5DbGFzczAxIDx8LS0gQXZlcnlMb25nQ2xhc3MgOiBDb29sXG48PGludGVyZmFjZT4-IENsYXNzMDFcbkNsYXNzMDkgLS0-IEMyIDogV2hlcmUgYW0gaT9cbkNsYXNzMDkgLS0qIEMzXG5DbGFzczA5IC0tfD4gQ2xhc3MwN1xuQ2xhc3MwNyA6IGVxdWFscygpXG5DbGFzczA3IDogT2JqZWN0W10gZWxlbWVudERhdGFcbkNsYXNzMDEgOiBzaXplKClcbkNsYXNzMDEgOiBpbnQgY2hpbXBcbkNsYXNzMDEgOiBpbnQgZ29yaWxsYVxuY2xhc3MgQ2xhc3MxMCB7XG4gID4-c2VydmljZT4-XG4gIGludCBpZFxuICBzaXplKClcbn0iLCJtZXJtYWlkIjp7InRoZW1lIjoiZGVmYXVsdCJ9fQ">live editor</a>] | ### 类图 [<a href="https://mermaid.js.org/syntax/classDiagram.html">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiY2xhc3NEaWFncmFtXG5DbGFzczAxIDx8LS0gQXZlcnlMb25nQ2xhc3MgOiBDb29sXG48PGludGVyZmFjZT4-IENsYXNzMDFcbkNsYXNzMDkgLS0-IEMyIDogV2hlcmUgYW0gaT9cbkNsYXNzMDkgLS0qIEMzXG5DbGFzczA5IC0tfD4gQ2xhc3MwN1xuQ2xhc3MwNyA6IGVxdWFscygpXG5DbGFzczA3IDogT2JqZWN0W10gZWxlbWVudERhdGFcbkNsYXNzMDEgOiBzaXplKClcbkNsYXNzMDEgOiBpbnQgY2hpbXBcbkNsYXNzMDEgOiBpbnQgZ29yaWxsYVxuY2xhc3MgQ2xhc3MxMCB7XG4gID4-c2VydmljZT4-XG4gIGludCBpZFxuICBzaXplKClcbn0iLCJtZXJtYWlkIjp7InRoZW1lIjoiZGVmYXVsdCJ9fQ">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| classDiagram | classDiagram | ||||||
| @@ -178,7 +178,7 @@ class Class10 { | |||||||
| } | } | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### 状态图 [[<a href="https://mermaid-js.github.io/mermaid/#/stateDiagram">docs</a> - <a href="https://mermaid.live/edit#pako:eNpdkLsOwjAMRX-l8ojahTEDCzB26kgYrMYtkfJAqVMJVf13QiIKqqfr44d8vUDvFYGAiZHponEMaJv5KF2V4na4V01zqjrWxhSUZYapuEetn7UbCy16P_5HzwGnR6FZfpdCDZaCRa3SWcunQQI_yJIEkaSiAaNhCdKtqRUj--7lehAcItUQn-pnBMSAZtroVWn2YYOU07b4z29Y37gJVYk">live editor</a>] | ### 状态图 [<a href="https://mermaid.js.org/syntax/stateDiagram.html">docs</a> - <a href="https://mermaid.live/edit#pako:eNpdkLsOwjAMRX-l8ojahTEDCzB26kgYrMYtkfJAqVMJVf13QiIKqqfr44d8vUDvFYGAiZHponEMaJv5KF2V4na4V01zqjrWxhSUZYapuEetn7UbCy16P_5HzwGnR6FZfpdCDZaCRa3SWcunQQI_yJIEkaSiAaNhCdKtqRUj--7lehAcItUQn-pnBMSAZtroVWn2YYOU07b4z29Y37gJVYk">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| stateDiagram-v2 | stateDiagram-v2 | ||||||
| @@ -200,7 +200,7 @@ Moving --> Crash | |||||||
| Crash --> [*] | Crash --> [*] | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### 饼图 [<a href="https://mermaid-js.github.io/mermaid/#/pie">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoicGllXG5cIkRvZ3NcIiA6IDQyLjk2XG5cIkNhdHNcIiA6IDUwLjA1XG5cIlJhdHNcIiA6IDEwLjAxIiwibWVybWFpZCI6eyJ0aGVtZSI6ImRlZmF1bHQifX0">live editor</a>] | ### 饼图 [<a href="https://mermaid.js.org/syntax/pie.html">文档</a> - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoicGllXG5cIkRvZ3NcIiA6IDQyLjk2XG5cIkNhdHNcIiA6IDUwLjA1XG5cIlJhdHNcIiA6IDEwLjAxIiwibWVybWFpZCI6eyJ0aGVtZSI6ImRlZmF1bHQifX0">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| pie | pie | ||||||
| @@ -218,7 +218,7 @@ pie | |||||||
|  |  | ||||||
| ### Git 图 [实验特性 - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiZ2l0R3JhcGg6XG5vcHRpb25zXG57XG4gICAgXCJub2RlU3BhY2luZ1wiOiAxNTAsXG4gICAgXCJub2RlUmFkaXVzXCI6IDEwXG59XG5lbmRcbmNvbW1pdFxuYnJhbmNoIG5ld2JyYW5jaFxuY2hlY2tvdXQgbmV3YnJhbmNoXG5jb21taXRcbmNvbW1pdFxuY2hlY2tvdXQgbWFzdGVyXG5jb21taXRcbmNvbW1pdFxubWVyZ2UgbmV3YnJhbmNoXG4iLCJtZXJtYWlkIjp7InRoZW1lIjoiZGVmYXVsdCJ9fQ">live editor</a>] | ### Git 图 [实验特性 - <a href="https://mermaid.live/edit#base64:eyJjb2RlIjoiZ2l0R3JhcGg6XG5vcHRpb25zXG57XG4gICAgXCJub2RlU3BhY2luZ1wiOiAxNTAsXG4gICAgXCJub2RlUmFkaXVzXCI6IDEwXG59XG5lbmRcbmNvbW1pdFxuYnJhbmNoIG5ld2JyYW5jaFxuY2hlY2tvdXQgbmV3YnJhbmNoXG5jb21taXRcbmNvbW1pdFxuY2hlY2tvdXQgbWFzdGVyXG5jb21taXRcbmNvbW1pdFxubWVyZ2UgbmV3YnJhbmNoXG4iLCJtZXJtYWlkIjp7InRoZW1lIjoiZGVmYXVsdCJ9fQ">live editor</a>] | ||||||
|  |  | ||||||
| ### 用户体验旅程图 [<a href="https://mermaid-js.github.io/mermaid/#/user-journey">文档</a> - <a href="https://mermaid.live/edit#pako:eNpljzEPgkAMhf9K05nFGJdbJXFiYmVpuKIncDVHL4QQ_ruHaILaqXnf63vpjLVYRoMAd4nB81R5SKNOO4ZiglFC6_wVLL3JwLU68XARUHnhTQcoqGVQJgMnAwV_5GSMj0HJhcHAcU_y7d7AYVUzOJP-ddyk3ydZGf0n66uldPqCPxWYYc-hJ2fTj_OqVqg3Tplo0mq5odhphZVfkpWiSjn5Go2GyBnGhyXl3NE1UI-moW7g5QkSoF5m">live editor</a>] | ### 用户体验旅程图 [<a href="https://mermaid.js.org/syntax/userJourney.html">文档</a> - <a href="https://mermaid.live/edit#pako:eNpljzEPgkAMhf9K05nFGJdbJXFiYmVpuKIncDVHL4QQ_ruHaILaqXnf63vpjLVYRoMAd4nB81R5SKNOO4ZiglFC6_wVLL3JwLU68XARUHnhTQcoqGVQJgMnAwV_5GSMj0HJhcHAcU_y7d7AYVUzOJP-ddyk3ydZGf0n66uldPqCPxWYYc-hJ2fTj_OqVqg3Tplo0mq5odhphZVfkpWiSjn5Go2GyBnGhyXl3NE1UI-moW7g5QkSoF5m">live editor</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|   journey |   journey | ||||||
| @@ -244,7 +244,7 @@ pie | |||||||
|       Sit down: 3: Me |       Sit down: 3: Me | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### C4 图 [<a href="https://mermaid-js.github.io/mermaid/#/c4c">文档</a>] | ### C4 图 [<a href="https://mermaid.js.org/syntax/c4.html">文档</a>] | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| C4Context | C4Context | ||||||
| @@ -338,7 +338,7 @@ npm publish | |||||||
|  |  | ||||||
| Mermaid 是一个不断发展中的社区,并且还在接收新的贡献者。有很多不同的方式可以参与进来,而且我们还在寻找额外的帮助。如果你想知道如何开始贡献,请查看 [这个 issue](https://github.com/mermaid-js/mermaid/issues/866)。 | Mermaid 是一个不断发展中的社区,并且还在接收新的贡献者。有很多不同的方式可以参与进来,而且我们还在寻找额外的帮助。如果你想知道如何开始贡献,请查看 [这个 issue](https://github.com/mermaid-js/mermaid/issues/866)。 | ||||||
|  |  | ||||||
| 关于如何贡献的详细信息可以在 [贡献指南](CONTRIBUTING.md) 中找到。 | 关于如何贡献的详细信息可以在 [贡献指南](https://mermaid.js.org/community/contributing.html) 中找到。 | ||||||
|  |  | ||||||
| ## 安全 | ## 安全 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,21 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked C4Context diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const drawPersonOrSystemArray = vi.fn(); |  | ||||||
| export const drawBoundary = vi.fn(); |  | ||||||
|  |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   drawPersonOrSystemArray, |  | ||||||
|   drawBoundary, |  | ||||||
|   setConf, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked class diagram v2 renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   setConf, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,13 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked class diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| // DO NOT delete this file. It is used by vitest to mock the dagre-d3 module. |  | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| module.exports = function (txt: string) { |  | ||||||
|   return txt; |  | ||||||
| }; |  | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked er diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   setConf, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked flow (flowchart) diagram v2 renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
| export const addVertices = vi.fn(); |  | ||||||
| export const addEdges = vi.fn(); |  | ||||||
| export const getClasses = vi.fn().mockImplementation(() => { |  | ||||||
|   return {}; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   setConf, |  | ||||||
|   addVertices, |  | ||||||
|   addEdges, |  | ||||||
|   getClasses, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked gantt diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   setConf, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,13 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked git (graph) diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked pie (picChart) diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   setConf, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked pie (picChart) diagram renderer |  | ||||||
|  */ |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| const draw = vi.fn().mockImplementation(() => ''); |  | ||||||
|  |  | ||||||
| export const renderer = { draw }; |  | ||||||
| @@ -1,13 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked requirement diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,13 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked Sankey diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked sequence diagram renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const bounds = vi.fn(); |  | ||||||
| export const drawActors = vi.fn(); |  | ||||||
| export const drawActorsPopup = vi.fn(); |  | ||||||
|  |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
|  |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   bounds, |  | ||||||
|   drawActors, |  | ||||||
|   drawActorsPopup, |  | ||||||
|   setConf, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Mocked state diagram v2 renderer |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { vi } from 'vitest'; |  | ||||||
|  |  | ||||||
| export const setConf = vi.fn(); |  | ||||||
| export const getClasses = vi.fn().mockImplementation(() => { |  | ||||||
|   return {}; |  | ||||||
| }); |  | ||||||
| export const stateDomId = vi.fn().mockImplementation(() => { |  | ||||||
|   return 'mocked-stateDiagram-stateDomId'; |  | ||||||
| }); |  | ||||||
| export const draw = vi.fn().mockImplementation(() => { |  | ||||||
|   return ''; |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|   setConf, |  | ||||||
|   getClasses, |  | ||||||
|   draw, |  | ||||||
| }; |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| // eslint-disable-next-line @typescript-eslint/no-var-requires |  | ||||||
| const { defineConfig } = require('cypress'); |  | ||||||
|  |  | ||||||
| module.exports = defineConfig({ |  | ||||||
|   testConcurrency: 1, |  | ||||||
|   browser: [ |  | ||||||
|     // Add browsers with different viewports |  | ||||||
|     //   { width: 800, height: 600, name: 'chrome' }, |  | ||||||
|     //   { width: 700, height: 500, name: 'firefox' }, |  | ||||||
|     //   { width: 1600, height: 1200, name: 'ie11' }, |  | ||||||
|     //   { width: 1024, height: 768, name: 'edgechromium' }, |  | ||||||
|     //   { width: 800, height: 600, name: 'safari' }, |  | ||||||
|     //   // Add mobile emulation devices in Portrait mode |  | ||||||
|     //   { deviceName: 'iPhone X', screenOrientation: 'portrait' }, |  | ||||||
|     //   { deviceName: 'Pixel 2', screenOrientation: 'portrait' }, |  | ||||||
|   ], |  | ||||||
|   // set batch name to the configuration |  | ||||||
|   // batchName: `Mermaid ${process.env.APPLI_BRANCH ?? "'no APPLI_BRANCH set'"}`, |  | ||||||
| }); |  | ||||||
							
								
								
									
										209
									
								
								cSpell.json
									
									
									
									
									
								
							
							
						
						
									
										209
									
								
								cSpell.json
									
									
									
									
									
								
							| @@ -1,209 +0,0 @@ | |||||||
| { |  | ||||||
|   "version": "0.2", |  | ||||||
|   "language": "en", |  | ||||||
|   "words": [ |  | ||||||
|     "acyclicer", |  | ||||||
|     "adamiecki", |  | ||||||
|     "alois", |  | ||||||
|     "aloisklink", |  | ||||||
|     "antiscript", |  | ||||||
|     "antlr", |  | ||||||
|     "appli", |  | ||||||
|     "applitools", |  | ||||||
|     "asciidoctor", |  | ||||||
|     "ashish", |  | ||||||
|     "ashishjain", |  | ||||||
|     "astah", |  | ||||||
|     "bbox", |  | ||||||
|     "bilkent", |  | ||||||
|     "bisheng", |  | ||||||
|     "blrs", |  | ||||||
|     "braintree", |  | ||||||
|     "brkt", |  | ||||||
|     "brolin", |  | ||||||
|     "brotli", |  | ||||||
|     "catmull", |  | ||||||
|     "città", |  | ||||||
|     "classdef", |  | ||||||
|     "codedoc", |  | ||||||
|     "codemia", |  | ||||||
|     "colour", |  | ||||||
|     "commitlint", |  | ||||||
|     "cpettitt", |  | ||||||
|     "customizability", |  | ||||||
|     "cuzon", |  | ||||||
|     "cytoscape", |  | ||||||
|     "dagre", |  | ||||||
|     "deepdwn", |  | ||||||
|     "descr", |  | ||||||
|     "docsify", |  | ||||||
|     "docsy", |  | ||||||
|     "doku", |  | ||||||
|     "dompurify", |  | ||||||
|     "dont", |  | ||||||
|     "doublecircle", |  | ||||||
|     "edgechromium", |  | ||||||
|     "elems", |  | ||||||
|     "elkjs", |  | ||||||
|     "elle", |  | ||||||
|     "faber", |  | ||||||
|     "flatmap", |  | ||||||
|     "foswiki", |  | ||||||
|     "frontmatter", |  | ||||||
|     "ftplugin", |  | ||||||
|     "gantt", |  | ||||||
|     "gitea", |  | ||||||
|     "gitgraph", |  | ||||||
|     "globby", |  | ||||||
|     "graphlib", |  | ||||||
|     "graphviz", |  | ||||||
|     "grav", |  | ||||||
|     "greywolf", |  | ||||||
|     "gzipped", |  | ||||||
|     "huynh", |  | ||||||
|     "huynhicode", |  | ||||||
|     "inkdrop", |  | ||||||
|     "jaoude", |  | ||||||
|     "jgreywolf", |  | ||||||
|     "jison", |  | ||||||
|     "jiti", |  | ||||||
|     "kaufmann", |  | ||||||
|     "khroma", |  | ||||||
|     "klemm", |  | ||||||
|     "klink", |  | ||||||
|     "knsv", |  | ||||||
|     "knut", |  | ||||||
|     "knutsveidqvist", |  | ||||||
|     "laganeckas", |  | ||||||
|     "linetype", |  | ||||||
|     "lintstagedrc", |  | ||||||
|     "logmsg", |  | ||||||
|     "lucida", |  | ||||||
|     "markdownish", |  | ||||||
|     "matthieu", |  | ||||||
|     "matthieumorel", |  | ||||||
|     "mdast", |  | ||||||
|     "mdbook", |  | ||||||
|     "mermaidjs", |  | ||||||
|     "mermerd", |  | ||||||
|     "mindaugas", |  | ||||||
|     "mindmap", |  | ||||||
|     "mindmaps", |  | ||||||
|     "mitigations", |  | ||||||
|     "mkdocs", |  | ||||||
|     "mmorel", |  | ||||||
|     "mult", |  | ||||||
|     "neurodiverse", |  | ||||||
|     "nextra", |  | ||||||
|     "nikolay", |  | ||||||
|     "nirname", |  | ||||||
|     "npmjs", |  | ||||||
|     "orlandoni", |  | ||||||
|     "pathe", |  | ||||||
|     "pbrolin", |  | ||||||
|     "phpbb", |  | ||||||
|     "pixelmatch", |  | ||||||
|     "plantuml", |  | ||||||
|     "playfair", |  | ||||||
|     "pnpm", |  | ||||||
|     "podlite", |  | ||||||
|     "quence", |  | ||||||
|     "radious", |  | ||||||
|     "ranksep", |  | ||||||
|     "rect", |  | ||||||
|     "rects", |  | ||||||
|     "reda", |  | ||||||
|     "redmine", |  | ||||||
|     "regexes", |  | ||||||
|     "rehype", |  | ||||||
|     "roledescription", |  | ||||||
|     "rozhkov", |  | ||||||
|     "sandboxed", |  | ||||||
|     "sankey", |  | ||||||
|     "setupgraphviewbox", |  | ||||||
|     "shiki", |  | ||||||
|     "sidharth", |  | ||||||
|     "sidharthv", |  | ||||||
|     "sphinxcontrib", |  | ||||||
|     "ssim", |  | ||||||
|     "startx", |  | ||||||
|     "starty", |  | ||||||
|     "statediagram", |  | ||||||
|     "steph", |  | ||||||
|     "stopx", |  | ||||||
|     "stopy", |  | ||||||
|     "stylis", |  | ||||||
|     "subhash-halder", |  | ||||||
|     "substate", |  | ||||||
|     "sulais", |  | ||||||
|     "sveidqvist", |  | ||||||
|     "swimm", |  | ||||||
|     "techn", |  | ||||||
|     "teststr", |  | ||||||
|     "textlength", |  | ||||||
|     "treemap", |  | ||||||
|     "ts-nocheck", |  | ||||||
|     "tsdoc", |  | ||||||
|     "tuleap", |  | ||||||
|     "tylerlong", |  | ||||||
|     "typora", |  | ||||||
|     "ugge", |  | ||||||
|     "unist", |  | ||||||
|     "unocss", |  | ||||||
|     "upvoting", |  | ||||||
|     "valign", |  | ||||||
|     "verdana", |  | ||||||
|     "viewports", |  | ||||||
|     "vinod", |  | ||||||
|     "visio", |  | ||||||
|     "vitepress", |  | ||||||
|     "vueuse", |  | ||||||
|     "xlink", |  | ||||||
|     "xychart", |  | ||||||
|     "yash", |  | ||||||
|     "yokozuna", |  | ||||||
|     "zenuml", |  | ||||||
|     "zune" |  | ||||||
|   ], |  | ||||||
|   "patterns": [ |  | ||||||
|     { "name": "Markdown links", "pattern": "\\((.*)\\)", "description": "" }, |  | ||||||
|     { |  | ||||||
|       "name": "Markdown code blocks", |  | ||||||
|       "pattern": "/^(\\s*`{3,}).*[\\s\\S]*?^\\1/gmx", |  | ||||||
|       "description": "Taken from the cSpell example at https://cspell.org/configuration/patterns/#verbose-regular-expressions" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "name": "Inline code blocks", |  | ||||||
|       "pattern": "\\`([^\\`\\r\\n]+?)\\`", |  | ||||||
|       "description": "https://stackoverflow.com/questions/41274241/how-to-capture-inline-markdown-code-but-not-a-markdown-code-fence-with-regex" |  | ||||||
|     }, |  | ||||||
|     { "name": "Link contents", "pattern": "\\<a(.*)\\>", "description": "" }, |  | ||||||
|     { "name": "Snippet references", "pattern": "-- snippet:(.*)", "description": "" }, |  | ||||||
|     { |  | ||||||
|       "name": "Snippet references 2", |  | ||||||
|       "pattern": "\\<\\[sample:(.*)", |  | ||||||
|       "description": "another kind of snippet reference" |  | ||||||
|     }, |  | ||||||
|     { "name": "Multi-line code blocks", "pattern": "/^\\s*```[\\s\\S]*?^\\s*```/gm" }, |  | ||||||
|     { |  | ||||||
|       "name": "HTML Tags", |  | ||||||
|       "pattern": "<[^>]*>", |  | ||||||
|       "description": "Reference: https://stackoverflow.com/questions/11229831/regular-expression-to-remove-html-tags-from-a-string" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "ignoreRegExpList": [ |  | ||||||
|     "Markdown links", |  | ||||||
|     "Markdown code blocks", |  | ||||||
|     "Inline code blocks", |  | ||||||
|     "Link contents", |  | ||||||
|     "Snippet references", |  | ||||||
|     "Snippet references 2", |  | ||||||
|     "Multi-line code blocks", |  | ||||||
|     "HTML Tags" |  | ||||||
|   ], |  | ||||||
|   "ignorePaths": [ |  | ||||||
|     "packages/mermaid/src/docs/CHANGELOG.md", |  | ||||||
|     "packages/mermaid/src/docs/.vitepress/redirect.ts", |  | ||||||
|     "packages/mermaid/src/docs/.vitepress/contributor-names.json" |  | ||||||
|   ] |  | ||||||
| } |  | ||||||
							
								
								
									
										45
									
								
								cspell.config.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								cspell.config.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | |||||||
|  | # yaml-language-server: $schema=https://raw.githubusercontent.com/streetsidesoftware/cspell/main/cspell.schema.json | ||||||
|  |  | ||||||
|  | $schema: https://raw.githubusercontent.com/streetsidesoftware/cspell/main/cspell.schema.json | ||||||
|  | version: '0.2' | ||||||
|  | language: en-US,en-GB | ||||||
|  |  | ||||||
|  | import: | ||||||
|  |   - ./.cspell/cspell.config.yaml | ||||||
|  |  | ||||||
|  | ignoreRegExpList: | ||||||
|  |   - character-set-cyrillic | ||||||
|  |   - svg-block | ||||||
|  | ignorePaths: | ||||||
|  |   - '*lock.{yaml,json}' | ||||||
|  |   - dist | ||||||
|  |   - CHANGELOG.md | ||||||
|  |   - packages/mermaid/src/docs/.vitepress/redirect.ts | ||||||
|  |   - packages/mermaid/src/docs/.vitepress/contributor-names.json | ||||||
|  |   - backup | ||||||
|  |   - '**/*.spec.{js,ts}' # checked by eslint | ||||||
|  |   - 'tests/webpack/src/index.js' # checked by eslint | ||||||
|  |   - 'cypress/**/*.js' # checked by eslint | ||||||
|  |   - '*.csv' | ||||||
|  |   - '*.patch' | ||||||
|  |   - 'docs/**/*.html' | ||||||
|  |   - 'cypress/platform/**' | ||||||
|  | dictionaries: | ||||||
|  |   - misc-terms | ||||||
|  | overrides: | ||||||
|  |   - filename: | ||||||
|  |       - '**/*.{jison,ts,mts,cjs,mjs,js,json,yaml,yml,md,html}' | ||||||
|  |       - 'run' | ||||||
|  |       - Dockerfile | ||||||
|  |     ignoreRegExpList: | ||||||
|  |       - js-unicode-escape | ||||||
|  |     dictionaries: | ||||||
|  |       - code-terms | ||||||
|  |       - 3rd-party-terms | ||||||
|  |       - fonts | ||||||
|  |       - html | ||||||
|  |       - lorem-ipsum | ||||||
|  |   - filename: '**/package.json' | ||||||
|  |     ignoreRegExpList: | ||||||
|  |       - json-property | ||||||
|  | # cspell:dictionaries code-terms | ||||||
| @@ -1,32 +0,0 @@ | |||||||
| /* eslint-disable @typescript-eslint/no-var-requires */ |  | ||||||
|  |  | ||||||
| const { defineConfig } = require('cypress'); |  | ||||||
| const { addMatchImageSnapshotPlugin } = require('cypress-image-snapshot/plugin'); |  | ||||||
| const coverage = require('@cypress/code-coverage/task'); |  | ||||||
|  |  | ||||||
| module.exports = defineConfig({ |  | ||||||
|   projectId: 'n2sma2', |  | ||||||
|   viewportWidth: 1440, |  | ||||||
|   viewportHeight: 1024, |  | ||||||
|   e2e: { |  | ||||||
|     specPattern: 'cypress/integration/**/*.{js,ts}', |  | ||||||
|     setupNodeEvents(on, config) { |  | ||||||
|       coverage(on, config); |  | ||||||
|       on('before:browser:launch', (browser = {}, launchOptions) => { |  | ||||||
|         if (browser.name === 'chrome' && browser.isHeadless) { |  | ||||||
|           launchOptions.args.push('--window-size=1440,1024', '--force-device-scale-factor=1'); |  | ||||||
|         } |  | ||||||
|         return launchOptions; |  | ||||||
|       }); |  | ||||||
|       addMatchImageSnapshotPlugin(on, config); |  | ||||||
|       // copy any needed variables from process.env to config.env |  | ||||||
|       config.env.useAppli = process.env.USE_APPLI ? true : false; |  | ||||||
|  |  | ||||||
|       // do not forget to return the changed config object! |  | ||||||
|       return config; |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
|   video: false, |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| require('@applitools/eyes-cypress')(module); |  | ||||||
							
								
								
									
										30
									
								
								cypress.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								cypress.config.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | import { defineConfig } from 'cypress'; | ||||||
|  | import { addMatchImageSnapshotPlugin } from 'cypress-image-snapshot/plugin'; | ||||||
|  | import coverage from '@cypress/code-coverage/task'; | ||||||
|  | import eyesPlugin from '@applitools/eyes-cypress'; | ||||||
|  | export default eyesPlugin( | ||||||
|  |   defineConfig({ | ||||||
|  |     projectId: 'n2sma2', | ||||||
|  |     viewportWidth: 1440, | ||||||
|  |     viewportHeight: 1024, | ||||||
|  |     e2e: { | ||||||
|  |       specPattern: 'cypress/integration/**/*.{js,ts}', | ||||||
|  |       setupNodeEvents(on, config) { | ||||||
|  |         coverage(on, config); | ||||||
|  |         on('before:browser:launch', (browser, launchOptions) => { | ||||||
|  |           if (browser.name === 'chrome' && browser.isHeadless) { | ||||||
|  |             launchOptions.args.push('--window-size=1440,1024', '--force-device-scale-factor=1'); | ||||||
|  |           } | ||||||
|  |           return launchOptions; | ||||||
|  |         }); | ||||||
|  |         addMatchImageSnapshotPlugin(on, config); | ||||||
|  |         // copy any needed variables from process.env to config.env | ||||||
|  |         config.env.useAppli = process.env.USE_APPLI ? true : false; | ||||||
|  |  | ||||||
|  |         // do not forget to return the changed config object! | ||||||
|  |         return config; | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |     video: false, | ||||||
|  |   }) | ||||||
|  | ); | ||||||
| @@ -118,11 +118,53 @@ describe('Configuration', () => { | |||||||
|     it('should not taint the initial configuration when using multiple directives', () => { |     it('should not taint the initial configuration when using multiple directives', () => { | ||||||
|       const url = 'http://localhost:9000/regression/issue-1874.html'; |       const url = 'http://localhost:9000/regression/issue-1874.html'; | ||||||
|       cy.visit(url); |       cy.visit(url); | ||||||
|  |       cy.window().should('have.property', 'rendered', true); | ||||||
|       cy.get('svg'); |       cy.get('svg').should('be.visible'); | ||||||
|       cy.matchImageSnapshot( |       cy.matchImageSnapshot( | ||||||
|         'configuration.spec-should-not-taint-initial-configuration-when-using-multiple-directives' |         'configuration.spec-should-not-taint-initial-configuration-when-using-multiple-directives' | ||||||
|       ); |       ); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   describe('suppressErrorRendering', () => { | ||||||
|  |     beforeEach(() => { | ||||||
|  |       cy.on('uncaught:exception', (err, runnable) => { | ||||||
|  |         return !err.message.includes('Parse error on line'); | ||||||
|  |       }); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should not render error diagram if suppressErrorRendering is set', () => { | ||||||
|  |       const url = 'http://localhost:9000/suppressError.html?suppressErrorRendering=true'; | ||||||
|  |       cy.visit(url); | ||||||
|  |       cy.window().should('have.property', 'rendered', true); | ||||||
|  |       cy.get('#test') | ||||||
|  |         .find('svg') | ||||||
|  |         .should(($svg) => { | ||||||
|  |           // all failing diagrams should not appear! | ||||||
|  |           expect($svg).to.have.length(2); | ||||||
|  |           // none of the diagrams should be error diagrams | ||||||
|  |           expect($svg).to.not.contain('Syntax error'); | ||||||
|  |         }); | ||||||
|  |       cy.matchImageSnapshot( | ||||||
|  |         'configuration.spec-should-not-render-error-diagram-if-suppressErrorRendering-is-set' | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should render error diagram if suppressErrorRendering is not set', () => { | ||||||
|  |       const url = 'http://localhost:9000/suppressError.html'; | ||||||
|  |       cy.visit(url); | ||||||
|  |       cy.window().should('have.property', 'rendered', true); | ||||||
|  |       cy.get('#test') | ||||||
|  |         .find('svg') | ||||||
|  |         .should(($svg) => { | ||||||
|  |           // all five diagrams should be rendered | ||||||
|  |           expect($svg).to.have.length(5); | ||||||
|  |           // some of the diagrams should be error diagrams | ||||||
|  |           expect($svg).to.contain('Syntax error'); | ||||||
|  |         }); | ||||||
|  |       cy.matchImageSnapshot( | ||||||
|  |         'configuration.spec-should-render-error-diagram-if-suppressErrorRendering-is-not-set' | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								cypress/integration/other/flowchart-elk.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								cypress/integration/other/flowchart-elk.spec.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | import { urlSnapshotTest, openURLAndVerifyRendering } from '../../helpers/util.ts'; | ||||||
|  |  | ||||||
|  | describe('Flowchart elk', () => { | ||||||
|  |   it('should use dagre as fallback', () => { | ||||||
|  |     urlSnapshotTest('http://localhost:9000/flow-elk.html', { | ||||||
|  |       name: 'flow-elk fallback to dagre', | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  |   it('should allow overriding with external package', () => { | ||||||
|  |     urlSnapshotTest('http://localhost:9000/flow-elk.html?elk=true', { | ||||||
|  |       name: 'flow-elk overriding dagre with elk', | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
							
								
								
									
										11
									
								
								cypress/integration/other/iife.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								cypress/integration/other/iife.spec.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | describe('IIFE', () => { | ||||||
|  |   beforeEach(() => { | ||||||
|  |     cy.visit('http://localhost:9000/iife.html'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('should render when using mermaid.min.js', () => { | ||||||
|  |     cy.window().should('have.property', 'rendered', true); | ||||||
|  |     cy.get('svg').should('be.visible'); | ||||||
|  |     cy.get('#d2').should('contain', 'Hello'); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| describe('Sequencediagram', () => { |  | ||||||
|   it('should render a simple sequence diagrams', () => { |  | ||||||
|     const url = 'http://localhost:9000/webpackUsage.html'; |  | ||||||
|  |  | ||||||
|     cy.visit(url); |  | ||||||
|     cy.get('body').find('svg').should('have.length', 1); |  | ||||||
|   }); |  | ||||||
|   it('should handle html escapings properly', () => { |  | ||||||
|     const url = 'http://localhost:9000/webpackUsage.html?test-html-escaping=true'; |  | ||||||
|  |  | ||||||
|     cy.visit(url); |  | ||||||
|     cy.get('body').find('svg').should('have.length', 1); |  | ||||||
|  |  | ||||||
|     cy.get('g.label > foreignobject > div').should('not.contain.text', '<b>'); |  | ||||||
|   }); |  | ||||||
| }); |  | ||||||
							
								
								
									
										386
									
								
								cypress/integration/rendering/block.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										386
									
								
								cypress/integration/rendering/block.spec.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,386 @@ | |||||||
|  | import { imgSnapshotTest } from '../../helpers/util'; | ||||||
|  | /* eslint-disable no-useless-escape */ | ||||||
|  | describe('Block diagram', () => { | ||||||
|  |   it('BL1: should calculate the block widths', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   columns 2 | ||||||
|  |   block | ||||||
|  |     id2["I am a wide one"] | ||||||
|  |     id1 | ||||||
|  |   end | ||||||
|  |   id["Next row"] | ||||||
|  |       ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL2: should handle colums statement in sub-blocks', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   id1["Hello"] | ||||||
|  |   block | ||||||
|  |     columns 3 | ||||||
|  |     id2["to"] | ||||||
|  |     id3["the"] | ||||||
|  |     id4["World"] | ||||||
|  |     id5["World"] | ||||||
|  |   end | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL3: should align block widths and handle colums statement in sub-blocks', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   block | ||||||
|  |     columns 1 | ||||||
|  |     id1 | ||||||
|  |     id2 | ||||||
|  |     id2.1 | ||||||
|  |   end | ||||||
|  |   id3 | ||||||
|  |   id4 | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL4: should align block widths and handle colums statements in deeper sub-blocks then 1 level', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   columns 1 | ||||||
|  |   block | ||||||
|  |     columns 1 | ||||||
|  |     block | ||||||
|  |       columns 3 | ||||||
|  |       id1 | ||||||
|  |       id2 | ||||||
|  |       id2.1(("XYZ")) | ||||||
|  |     end | ||||||
|  |     id48 | ||||||
|  |   end | ||||||
|  |   id3 | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL5: should align block widths and handle colums statements in deeper sub-blocks then 1 level (alt)', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   columns 1 | ||||||
|  |   block | ||||||
|  |     id1 | ||||||
|  |     id2 | ||||||
|  |     block | ||||||
|  |       columns 1 | ||||||
|  |       id3("Wider then") | ||||||
|  |       id5(("id5")) | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  |   id4 | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL6: should handle block arrows and spece statements', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     columns 3 | ||||||
|  |     space:3 | ||||||
|  |     ida idb idc | ||||||
|  |     id1  id2 | ||||||
|  |       blockArrowId<["Label"]>(right) | ||||||
|  |       blockArrowId2<["Label"]>(left) | ||||||
|  |       blockArrowId3<["Label"]>(up) | ||||||
|  |       blockArrowId4<["Label"]>(down) | ||||||
|  |       blockArrowId5<["Label"]>(x) | ||||||
|  |       blockArrowId6<["Label"]>(y) | ||||||
|  |       blockArrowId6<["Label"]>(x, down) | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL7: should handle different types of edges', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       columns 3 | ||||||
|  |       A space:5 | ||||||
|  |       A --o B | ||||||
|  |       A --> C | ||||||
|  |       A --x D | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL8: should handle sub-blocks without columns statements', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       columns 2 | ||||||
|  |       C A B | ||||||
|  |       block | ||||||
|  |         D | ||||||
|  |         E | ||||||
|  |       end | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL9: should handle edges from blocks in sub blocks to other blocks', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       columns 3 | ||||||
|  |       B space | ||||||
|  |       block | ||||||
|  |         D | ||||||
|  |       end | ||||||
|  |       D --> B | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL10: should handle edges from composite blocks', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       columns 3 | ||||||
|  |       B space | ||||||
|  |       block BL | ||||||
|  |         D | ||||||
|  |       end | ||||||
|  |       BL --> B | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL11: should handle edges to composite blocks', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       columns 3 | ||||||
|  |       B space | ||||||
|  |       block BL | ||||||
|  |         D | ||||||
|  |       end | ||||||
|  |       B --> BL | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL12: edges should handle labels', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       A | ||||||
|  |       space | ||||||
|  |       A -- "apa" --> E | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL13: should handle block arrows in different directions', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       columns 3 | ||||||
|  |       space blockArrowId1<["down"]>(down) space | ||||||
|  |       blockArrowId2<["right"]>(right) blockArrowId3<["Sync"]>(x, y) blockArrowId4<["left"]>(left) | ||||||
|  |       space blockArrowId5<["up"]>(up) space | ||||||
|  |       blockArrowId6<["x"]>(x) space blockArrowId7<["y"]>(y) | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL14: should style statements and class statements', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     A | ||||||
|  |     B | ||||||
|  |     classDef blue fill:#66f,stroke:#333,stroke-width:2px; | ||||||
|  |     class A blue | ||||||
|  |     style B fill:#f9F,stroke:#333,stroke-width:4px | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL15: width alignment - D and E should share available space', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   block | ||||||
|  |     D | ||||||
|  |     E | ||||||
|  |   end | ||||||
|  |   db("This is the text in the box") | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL16: width alignment - C should be as wide as the composite block', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   block | ||||||
|  |     A("This is the text") | ||||||
|  |     B | ||||||
|  |   end | ||||||
|  |   C | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL16: width alignment - blocks shold be equal in width', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     A("This is the text") | ||||||
|  |     B | ||||||
|  |     C | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL17: block types 1 - square, rounded and circle', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     A["square"] | ||||||
|  |     B("rounded") | ||||||
|  |     C(("circle")) | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL18: block types 2 - odd, diamond and hexagon', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     A>"rect_left_inv_arrow"] | ||||||
|  |     B{"diamond"} | ||||||
|  |     C{{"hexagon"}} | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL19: block types 3 - stadium', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     A(["stadium"]) | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL20: block types 4 - lean right, lean left, trapezoid and inv trapezoid', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     A[/"lean right"/] | ||||||
|  |     B[\"lean left"\] | ||||||
|  |     C[/"trapezoid"\] | ||||||
|  |     D[\"trapezoid alt"/] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL21: block types 1 - square, rounded and circle', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |     A["square"] | ||||||
|  |     B("rounded") | ||||||
|  |     C(("circle")) | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL22: sizing - it should be possible to make a block wider', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       A("rounded"):2 | ||||||
|  |       B:2 | ||||||
|  |       C | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL23: sizing - it should be possible to make a composite block wider', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |       block:2 | ||||||
|  |         A | ||||||
|  |       end | ||||||
|  |       B | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('BL24: block in the middle with space on each side', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |         columns 3 | ||||||
|  |         space | ||||||
|  |         middle["In the middle"] | ||||||
|  |         space | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('BL25: space and an edge', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   columns 5 | ||||||
|  |     A space B | ||||||
|  |     A --x B | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('BL26: block sizes for regular blocks', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   columns 3 | ||||||
|  |     a["A wide one"] b:2 c:2 d | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('BL27: composite block with a set width - f should use the available space', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   columns 3 | ||||||
|  |   a:3 | ||||||
|  |   block:e:3 | ||||||
|  |       f | ||||||
|  |   end | ||||||
|  |   g | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('BL23: composite block with a set width - f and g should split the available space', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `block-beta | ||||||
|  |   columns 3 | ||||||
|  |   a:3 | ||||||
|  |   block:e:3 | ||||||
|  |       f | ||||||
|  |       g | ||||||
|  |   end | ||||||
|  |   h | ||||||
|  |   i | ||||||
|  |   j | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
| @@ -844,3 +844,42 @@ end | |||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | describe('Title and arrow styling #4813', () => { | ||||||
|  |   it('should render a flowchart with title', () => { | ||||||
|  |     const titleString = 'Test Title'; | ||||||
|  |     renderGraph( | ||||||
|  |       `--- | ||||||
|  |       title: ${titleString} | ||||||
|  |       --- | ||||||
|  |       flowchart LR | ||||||
|  |       A-->B | ||||||
|  |       A-->C`, | ||||||
|  |       { flowchart: { defaultRenderer: 'elk' } } | ||||||
|  |     ); | ||||||
|  |     cy.get('svg').should((svg) => { | ||||||
|  |       const title = svg[0].querySelector('text'); | ||||||
|  |       expect(title.textContent).to.contain(titleString); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('Render with stylized arrows', () => { | ||||||
|  |     renderGraph( | ||||||
|  |       ` | ||||||
|  |       flowchart LR | ||||||
|  |       A-->B | ||||||
|  |       B-.-oC | ||||||
|  |       C==xD | ||||||
|  |       D ~~~ A`, | ||||||
|  |       { flowchart: { defaultRenderer: 'elk' } } | ||||||
|  |     ); | ||||||
|  |     cy.get('svg').should((svg) => { | ||||||
|  |       const edges = svg[0].querySelectorAll('.edges path'); | ||||||
|  |       console.log(edges); | ||||||
|  |       expect(edges[0]).to.have.attr('pattern', 'solid'); | ||||||
|  |       expect(edges[1]).to.have.attr('pattern', 'dotted'); | ||||||
|  |       expect(edges[2]).to.have.css('stroke-width', '3.5px'); | ||||||
|  |       expect(edges[3]).to.have.css('stroke-width', '1.5px'); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
|   | |||||||
| @@ -760,6 +760,51 @@ A ~~~ B | |||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   it('3258: Should render subgraphs with main graph nodeSpacing and rankSpacing', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `--- | ||||||
|  |       title: Subgraph nodeSpacing and rankSpacing example | ||||||
|  |       --- | ||||||
|  |       flowchart LR | ||||||
|  |         X --> Y | ||||||
|  |         subgraph X | ||||||
|  |           direction LR | ||||||
|  |           A | ||||||
|  |           C | ||||||
|  |         end | ||||||
|  |         subgraph Y | ||||||
|  |           B | ||||||
|  |           D | ||||||
|  |         end | ||||||
|  |       `, | ||||||
|  |       { flowchart: { nodeSpacing: 1, rankSpacing: 1 } } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('3258: Should render subgraphs with large nodeSpacing and rankSpacing', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `--- | ||||||
|  |       title: Subgraph nodeSpacing and rankSpacing example | ||||||
|  |       config: | ||||||
|  |         flowchart:  | ||||||
|  |           nodeSpacing: 250 | ||||||
|  |           rankSpacing: 250 | ||||||
|  |       --- | ||||||
|  |       flowchart LR | ||||||
|  |         X --> Y | ||||||
|  |         subgraph X | ||||||
|  |           direction LR | ||||||
|  |           A | ||||||
|  |           C | ||||||
|  |         end | ||||||
|  |         subgraph Y | ||||||
|  |           B | ||||||
|  |           D | ||||||
|  |         end | ||||||
|  |       ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|   describe('Markdown strings flowchart (#4220)', () => { |   describe('Markdown strings flowchart (#4220)', () => { | ||||||
|     describe('html labels', () => { |     describe('html labels', () => { | ||||||
|       it('With styling and classes', () => { |       it('With styling and classes', () => { | ||||||
| @@ -904,6 +949,18 @@ end | |||||||
|         ); |         ); | ||||||
|       }); |       }); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|  |     it('should not auto wrap when markdownAutoWrap is false', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `flowchart TD | ||||||
|  |     angular_velocity["\`**angular_velocity** | ||||||
|  |       *angular_displacement / duration* | ||||||
|  |       [rad/s, 1/s] | ||||||
|  |       {vector}\`"] | ||||||
|  |     frequency["frequency\n(1 / period_duration)\n[Hz, 1/s]"]`, | ||||||
|  |         { markdownAutoWrap: false } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|   }); |   }); | ||||||
|   describe('Subgraph title margins', () => { |   describe('Subgraph title margins', () => { | ||||||
|     it('Should render subgraphs with title margins set (LR)', () => { |     it('Should render subgraphs with title margins set (LR)', () => { | ||||||
|   | |||||||
| @@ -92,6 +92,31 @@ describe('Gantt diagram', () => { | |||||||
|       {} |       {} | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |   it('should handle multiple dependencies syntax with after and until', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       gantt | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       axisFormat  %d/%m | ||||||
|  |       title Adding GANTT diagram to mermaid | ||||||
|  |       excludes weekdays 2014-01-10 | ||||||
|  |       todayMarker off | ||||||
|  |  | ||||||
|  |       section team's critical event | ||||||
|  |       deadline A           :milestone, crit, deadlineA, 2024-02-01, 0 | ||||||
|  |       deadline B           :milestone, crit, deadlineB, 2024-02-15, 0 | ||||||
|  |       boss on leave        :bossaway, 2024-01-28, 2024-02-11 | ||||||
|  |  | ||||||
|  |       section new intern | ||||||
|  |       onboarding           :onboarding, 2024-01-02, 1w | ||||||
|  |       literature review    :litreview, 2024-01-02, 10d | ||||||
|  |       project A            :projectA, after onboarding litreview, until deadlineA bossaway | ||||||
|  |       chilling             :chilling, after projectA, until deadlineA | ||||||
|  |       project B            :projectB, after deadlineA, until deadlineB | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|   it('should FAIL redering a gantt chart for issue #1060 with invalid date', () => { |   it('should FAIL redering a gantt chart for issue #1060 with invalid date', () => { | ||||||
|     imgSnapshotTest( |     imgSnapshotTest( | ||||||
|       ` |       ` | ||||||
| @@ -548,7 +573,28 @@ describe('Gantt diagram', () => { | |||||||
|       ` |       ` | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |   it('should render a gantt diagram exculding friday and saturday', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `gantt | ||||||
|  |       title A Gantt Diagram | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       excludes weekends | ||||||
|  |       weekend friday | ||||||
|  |       section Section1 | ||||||
|  |       A task :a1, 2024-02-28, 10d` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('should render a gantt diagram exculding saturday and sunday', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `gantt | ||||||
|  |       title A Gantt Diagram | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       excludes weekends | ||||||
|  |       weekend saturday | ||||||
|  |       section Section1 | ||||||
|  |       A task :a1, 2024-02-28, 10d` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|   it('should render when compact is true', () => { |   it('should render when compact is true', () => { | ||||||
|     imgSnapshotTest( |     imgSnapshotTest( | ||||||
|       ` |       ` | ||||||
| @@ -583,4 +629,106 @@ describe('Gantt diagram', () => { | |||||||
|       {} |       {} | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   it("should render when there's a semicolon in the title", () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       gantt | ||||||
|  |       title ;Gantt With a Semicolon in the Title | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       section Section | ||||||
|  |       A task           :a1, 2014-01-01, 30d | ||||||
|  |       Another task     :after a1  , 20d | ||||||
|  |       section Another | ||||||
|  |       Task in sec      :2014-01-12  , 12d | ||||||
|  |       another task      : 24d | ||||||
|  |     `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it("should render when there's a semicolon in a section is true", () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       gantt | ||||||
|  |       title Gantt Digram | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       section ;Section With a Semicolon | ||||||
|  |       A task           :a1, 2014-01-01, 30d | ||||||
|  |       Another task     :after a1  , 20d | ||||||
|  |       section Another | ||||||
|  |       Task in sec      :2014-01-12  , 12d | ||||||
|  |       another task      : 24d | ||||||
|  |     `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it("should render when there's a semicolon in the task data", () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       gantt | ||||||
|  |       title Gantt Digram | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       section Section | ||||||
|  |       ;A task with a semiclon           :a1, 2014-01-01, 30d | ||||||
|  |       Another task     :after a1  , 20d | ||||||
|  |       section Another | ||||||
|  |       Task in sec      :2014-01-12  , 12d | ||||||
|  |       another task      : 24d | ||||||
|  |     `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it("should render when there's a hashtag in the title", () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       gantt | ||||||
|  |       title #Gantt With a Hashtag in the Title | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       section Section | ||||||
|  |       A task           :a1, 2014-01-01, 30d | ||||||
|  |       Another task     :after a1  , 20d | ||||||
|  |       section Another | ||||||
|  |       Task in sec      :2014-01-12  , 12d | ||||||
|  |       another task      : 24d | ||||||
|  |     `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it("should render when there's a hashtag in a section is true", () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       gantt | ||||||
|  |       title Gantt Digram | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       section #Section With a Hashtag | ||||||
|  |       A task           :a1, 2014-01-01, 30d | ||||||
|  |       Another task     :after a1  , 20d | ||||||
|  |       section Another | ||||||
|  |       Task in sec      :2014-01-12  , 12d | ||||||
|  |       another task      : 24d | ||||||
|  |     `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it("should render when there's a hashtag in the task data", () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       gantt | ||||||
|  |       title Gantt Digram | ||||||
|  |       dateFormat  YYYY-MM-DD | ||||||
|  |       section Section | ||||||
|  |       #A task with a hashtag           :a1, 2014-01-01, 30d | ||||||
|  |       Another task     :after a1  , 20d | ||||||
|  |       section Another | ||||||
|  |       Task in sec      :2014-01-12  , 12d | ||||||
|  |       another task      : 24d | ||||||
|  |     `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -943,4 +943,594 @@ gitGraph TB: | |||||||
|       { gitGraph: { parallelCommits: true } } |       { gitGraph: { parallelCommits: true } } | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
|  |   it('46: should render GitGraph with merge back and merge forward', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `gitGraph LR: | ||||||
|  |       commit id:"1-abcdefg" | ||||||
|  |  | ||||||
|  |       branch branch-A | ||||||
|  |       branch branch-B | ||||||
|  |       commit id:"2-abcdefg" | ||||||
|  |  | ||||||
|  |       checkout branch-A | ||||||
|  |       merge branch-B | ||||||
|  |  | ||||||
|  |       checkout branch-B | ||||||
|  |       merge branch-A | ||||||
|  |       `, | ||||||
|  |       { gitGraph: { parallelCommits: true } } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('47: should render GitGraph with merge back and merge forward | Vertical Branch', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `gitGraph TB: | ||||||
|  |       commit id:"1-abcdefg" | ||||||
|  |  | ||||||
|  |       branch branch-A | ||||||
|  |       branch branch-B | ||||||
|  |       commit id:"2-abcdefg" | ||||||
|  |  | ||||||
|  |       checkout branch-A | ||||||
|  |       merge branch-B | ||||||
|  |  | ||||||
|  |       checkout branch-B | ||||||
|  |       merge branch-A | ||||||
|  |       `, | ||||||
|  |       { gitGraph: { parallelCommits: true } } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('48: should render GitGraph with merge on a new branch | Vertical Branch', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `gitGraph LR: | ||||||
|  |       commit id:"1-abcdefg" | ||||||
|  |  | ||||||
|  |       branch branch-B order: 2 | ||||||
|  |       commit id:"2-abcdefg" | ||||||
|  |  | ||||||
|  |       branch branch-A | ||||||
|  |       merge main | ||||||
|  |  | ||||||
|  |       checkout branch-B | ||||||
|  |       merge branch-A | ||||||
|  |       `, | ||||||
|  |       { gitGraph: { parallelCommits: true } } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('49: should render GitGraph with merge on a new branch | Vertical Branch', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `gitGraph TB: | ||||||
|  |       commit id:"1-abcdefg" | ||||||
|  |  | ||||||
|  |       branch branch-B order: 2 | ||||||
|  |       commit id:"2-abcdefg" | ||||||
|  |  | ||||||
|  |       branch branch-A | ||||||
|  |       merge main | ||||||
|  |  | ||||||
|  |       checkout branch-B | ||||||
|  |       merge branch-A | ||||||
|  |       `, | ||||||
|  |       { gitGraph: { parallelCommits: true } } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   describe('Git-Graph Bottom-to-Top Orientation Tests', () => { | ||||||
|  |     it('50: should render a simple gitgraph with commit on main branch | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "1" | ||||||
|  |          commit id: "2" | ||||||
|  |          commit id: "3" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('51: should render a simple gitgraph with commit on main branch with Id | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "One" | ||||||
|  |          commit id: "Two" | ||||||
|  |          commit id: "Three" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('52: should render a simple gitgraph with different commitTypes on main branch | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "Normal Commit" | ||||||
|  |          commit id: "Reverse Commit" type: REVERSE | ||||||
|  |          commit id: "Highlight Commit" type: HIGHLIGHT | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('53: should render a simple gitgraph with tags commitTypes on main branch | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "Normal Commit with tag" tag: "v1.0.0" | ||||||
|  |          commit id: "Reverse Commit with tag" type: REVERSE tag: "RC_1" | ||||||
|  |          commit id: "Highlight Commit" type: HIGHLIGHT  tag: "8.8.4" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('54: should render a simple gitgraph with two branches | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "1" | ||||||
|  |          commit id: "2" | ||||||
|  |          branch develop | ||||||
|  |          checkout develop | ||||||
|  |          commit id: "3" | ||||||
|  |          commit id: "4" | ||||||
|  |          checkout main | ||||||
|  |          commit id: "5" | ||||||
|  |          commit id: "6" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('55: should render a simple gitgraph with two branches and merge commit | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "1" | ||||||
|  |          commit id: "2" | ||||||
|  |          branch develop | ||||||
|  |          checkout develop | ||||||
|  |          commit id: "3" | ||||||
|  |          commit id: "4" | ||||||
|  |          checkout main | ||||||
|  |          merge develop | ||||||
|  |          commit id: "5" | ||||||
|  |          commit id: "6" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('56: should render a simple gitgraph with three branches and tagged merge commit | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "1" | ||||||
|  |          commit id: "2" | ||||||
|  |          branch nice_feature | ||||||
|  |          checkout nice_feature | ||||||
|  |          commit id: "3" | ||||||
|  |          checkout main | ||||||
|  |          commit id: "4" | ||||||
|  |          checkout nice_feature | ||||||
|  |          branch very_nice_feature | ||||||
|  |          checkout very_nice_feature | ||||||
|  |          commit id: "5" | ||||||
|  |          checkout main | ||||||
|  |          commit id: "6" | ||||||
|  |          checkout nice_feature | ||||||
|  |          commit id: "7" | ||||||
|  |          checkout main | ||||||
|  |          merge nice_feature id: "12345" tag: "my merge commit" | ||||||
|  |          checkout very_nice_feature | ||||||
|  |          commit id: "8" | ||||||
|  |          checkout main | ||||||
|  |          commit id: "9" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('57: should render a simple gitgraph with more than 8 branches &  overriding variables | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `%%{init: { 'logLevel': 'debug', 'theme': 'default' , 'themeVariables': { | ||||||
|  |           'gitBranchLabel0': '#ffffff', | ||||||
|  |           'gitBranchLabel1': '#ffffff', | ||||||
|  |           'gitBranchLabel2': '#ffffff', | ||||||
|  |           'gitBranchLabel3': '#ffffff', | ||||||
|  |           'gitBranchLabel4': '#ffffff', | ||||||
|  |           'gitBranchLabel5': '#ffffff', | ||||||
|  |           'gitBranchLabel6': '#ffffff', | ||||||
|  |           'gitBranchLabel7': '#ffffff', | ||||||
|  |     } } }%% | ||||||
|  |     gitGraph BT: | ||||||
|  |       checkout main | ||||||
|  |       branch branch1 | ||||||
|  |       branch branch2 | ||||||
|  |       branch branch3 | ||||||
|  |       branch branch4 | ||||||
|  |       branch branch5 | ||||||
|  |       branch branch6 | ||||||
|  |       branch branch7 | ||||||
|  |       branch branch8 | ||||||
|  |       branch branch9 | ||||||
|  |       checkout branch1 | ||||||
|  |       commit id: "1" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('58: should render a simple gitgraph with rotated labels | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `%%{init: { 'logLevel': 'debug', 'theme': 'default' , 'gitGraph': { | ||||||
|  |           'rotateCommitLabel': true | ||||||
|  |     } } }%% | ||||||
|  |           gitGraph BT: | ||||||
|  |           commit id: "75f7219e83b321cd3fdde7dcf83bc7c1000a6828" | ||||||
|  |           commit id: "0db4784daf82736dec4569e0dc92980d328c1f2e" | ||||||
|  |           commit id: "7067e9973f9eaa6cd4a4b723c506d1eab598e83e" | ||||||
|  |           commit id: "66972321ad6c199013b5b31f03b3a86fa3f9817d" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('59: should render a simple gitgraph with horizontal labels | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `%%{init: { 'logLevel': 'debug', 'theme': 'default' , 'gitGraph': { | ||||||
|  |           'rotateCommitLabel': false | ||||||
|  |     } } }%% | ||||||
|  |           gitGraph BT: | ||||||
|  |           commit id: "Alpha" | ||||||
|  |           commit id: "Beta" | ||||||
|  |           commit id: "Gamma" | ||||||
|  |           commit id: "Delta" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('60: should render a simple gitgraph with cherry pick commit | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         ` | ||||||
|  |       gitGraph BT: | ||||||
|  |          commit id: "ZERO" | ||||||
|  |          branch develop | ||||||
|  |          commit id:"A" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"ONE" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"B" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"TWO" | ||||||
|  |          cherry-pick id:"A" | ||||||
|  |          commit id:"THREE" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"C" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('61: should render a gitgraph with cherry pick commit with custom tag | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         ` | ||||||
|  |       gitGraph BT: | ||||||
|  |          commit id: "ZERO" | ||||||
|  |          branch develop | ||||||
|  |          commit id:"A" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"ONE" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"B" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"TWO" | ||||||
|  |          cherry-pick id:"A" tag: "snapshot" | ||||||
|  |          commit id:"THREE" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"C" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('62: should render a gitgraph with cherry pick commit with no tag | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         ` | ||||||
|  |       gitGraph BT: | ||||||
|  |          commit id: "ZERO" | ||||||
|  |          branch develop | ||||||
|  |          commit id:"A" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"ONE" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"B" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"TWO" | ||||||
|  |          cherry-pick id:"A" tag: "" | ||||||
|  |          commit id:"THREE" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"C" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('63: should render a simple gitgraph with two cherry pick commit | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         ` | ||||||
|  |       gitGraph BT: | ||||||
|  |          commit id: "ZERO" | ||||||
|  |          branch develop | ||||||
|  |          commit id:"A" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"ONE" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"B" | ||||||
|  |          branch featureA | ||||||
|  |          commit id:"FIX" | ||||||
|  |          commit id: "FIX-2" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"TWO" | ||||||
|  |          cherry-pick id:"A" | ||||||
|  |          commit id:"THREE" | ||||||
|  |          cherry-pick id:"FIX" | ||||||
|  |          checkout develop | ||||||
|  |          commit id:"C" | ||||||
|  |          merge featureA | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('64: should render commits for more than 8 branches | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         ` | ||||||
|  |         gitGraph BT: | ||||||
|  |         checkout main | ||||||
|  |         %% Make sure to manually set the ID of all commits, for consistent visual tests | ||||||
|  |         commit id: "1-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         branch branch1 | ||||||
|  |         commit id: "2-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch1 | ||||||
|  |         branch branch2 | ||||||
|  |         commit id: "3-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch2 | ||||||
|  |         branch branch3 | ||||||
|  |         commit id: "4-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch3 | ||||||
|  |         branch branch4 | ||||||
|  |         commit id: "5-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch4 | ||||||
|  |         branch branch5 | ||||||
|  |         commit id: "6-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch5 | ||||||
|  |         branch branch6 | ||||||
|  |         commit id: "7-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch6 | ||||||
|  |         branch branch7 | ||||||
|  |         commit id: "8-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch7 | ||||||
|  |         branch branch8 | ||||||
|  |         commit id: "9-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge branch8 | ||||||
|  |         branch branch9 | ||||||
|  |         commit id: "10-abcdefg" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('65: should render a simple gitgraph with three branches,custom merge commit id,tag,type | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id: "1" | ||||||
|  |          commit id: "2" | ||||||
|  |          branch nice_feature | ||||||
|  |          checkout nice_feature | ||||||
|  |          commit id: "3" | ||||||
|  |          checkout main | ||||||
|  |          commit id: "4" | ||||||
|  |          checkout nice_feature | ||||||
|  |          branch very_nice_feature | ||||||
|  |          checkout very_nice_feature | ||||||
|  |          commit id: "5" | ||||||
|  |          checkout main | ||||||
|  |          commit id: "6" | ||||||
|  |          checkout nice_feature | ||||||
|  |          commit id: "7" | ||||||
|  |          checkout main | ||||||
|  |          merge nice_feature id: "customID" tag: "customTag" type: REVERSE | ||||||
|  |          checkout very_nice_feature | ||||||
|  |          commit id: "8" | ||||||
|  |          checkout main | ||||||
|  |          commit id: "9" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('66: should render a simple gitgraph with a title | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `--- | ||||||
|  |   title: simple gitGraph | ||||||
|  |   --- | ||||||
|  |   gitGraph BT: | ||||||
|  |     commit id: "1-abcdefg" | ||||||
|  |   `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('67: should render a simple gitgraph overlapping commits | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |          commit id:"s1" | ||||||
|  |          commit id:"s2" | ||||||
|  |          branch branch1 | ||||||
|  |          commit id:"s3" | ||||||
|  |          commit id:"s4" | ||||||
|  |          checkout main | ||||||
|  |          commit id:"s5" | ||||||
|  |          checkout branch1 | ||||||
|  |          commit id:"s6" | ||||||
|  |          commit id:"s7" | ||||||
|  |          merge main | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('68: should render a simple gitgraph with two branches from same commit | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |         commit id:"1-abcdefg" | ||||||
|  |         commit id:"2-abcdefg" | ||||||
|  |         branch feature-001 | ||||||
|  |         commit id:"3-abcdefg" | ||||||
|  |         commit id:"4-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         branch feature-002 | ||||||
|  |         commit id:"5-abcdefg" | ||||||
|  |         checkout feature-001 | ||||||
|  |         merge feature-002 | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('69: should render GitGraph with branch that is not used immediately | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |         commit id:"1-abcdefg" | ||||||
|  |         branch x | ||||||
|  |         checkout main | ||||||
|  |         commit id:"2-abcdefg" | ||||||
|  |         checkout x | ||||||
|  |         commit id:"3-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge x | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('70: should render GitGraph with branch and sub-branch neither of which used immediately | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |         commit id:"1-abcdefg" | ||||||
|  |         branch x | ||||||
|  |         checkout main | ||||||
|  |         commit id:"2-abcdefg" | ||||||
|  |         checkout x | ||||||
|  |         commit id:"3-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         merge x | ||||||
|  |         checkout x | ||||||
|  |         branch y | ||||||
|  |         checkout x | ||||||
|  |         commit id:"4-abcdefg" | ||||||
|  |         checkout y | ||||||
|  |         commit id:"5-abcdefg" | ||||||
|  |         checkout x | ||||||
|  |         merge y | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('71: should render GitGraph with parallel commits | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |         commit id:"1-abcdefg" | ||||||
|  |         commit id:"2-abcdefg" | ||||||
|  |         branch develop | ||||||
|  |         commit id:"3-abcdefg" | ||||||
|  |         commit id:"4-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         branch feature | ||||||
|  |         commit id:"5-abcdefg" | ||||||
|  |         commit id:"6-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         commit id:"7-abcdefg" | ||||||
|  |         commit id:"8-abcdefg" | ||||||
|  |         `, | ||||||
|  |         { gitGraph: { parallelCommits: true } } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('72: should render GitGraph with unconnected branches and parallel commits | Vertical Branch - Bottom-to-top', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph BT: | ||||||
|  |         branch dev | ||||||
|  |         branch v2 | ||||||
|  |         branch feat | ||||||
|  |         commit id:"1-abcdefg" | ||||||
|  |         commit id:"2-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         commit id:"3-abcdefg" | ||||||
|  |         checkout dev | ||||||
|  |         commit id:"4-abcdefg" | ||||||
|  |         checkout v2 | ||||||
|  |         commit id:"5-abcdefg" | ||||||
|  |         checkout main | ||||||
|  |         commit id:"6-abcdefg" | ||||||
|  |         `, | ||||||
|  |         { gitGraph: { parallelCommits: true } } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('73: should render a simple gitgraph with three branches and tagged merge commit using switch instead of checkout', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         `gitGraph | ||||||
|  |          commit id: "1" | ||||||
|  |          commit id: "2" | ||||||
|  |          branch nice_feature | ||||||
|  |          switch nice_feature | ||||||
|  |          commit id: "3" | ||||||
|  |          switch main | ||||||
|  |          commit id: "4" | ||||||
|  |          switch nice_feature | ||||||
|  |          branch very_nice_feature | ||||||
|  |          switch very_nice_feature | ||||||
|  |          commit id: "5" | ||||||
|  |          switch main | ||||||
|  |          commit id: "6" | ||||||
|  |          switch nice_feature | ||||||
|  |          commit id: "7" | ||||||
|  |          switch main | ||||||
|  |          merge nice_feature id: "12345" tag: "my merge commit" | ||||||
|  |          switch very_nice_feature | ||||||
|  |          commit id: "8" | ||||||
|  |          switch main | ||||||
|  |          commit id: "9" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it('74: should render commits for more than 8 branches using switch instead of checkout', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         ` | ||||||
|  |         gitGraph | ||||||
|  |         switch main | ||||||
|  |         %% Make sure to manually set the ID of all commits, for consistent visual tests | ||||||
|  |         commit id: "1-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         branch branch1 | ||||||
|  |         commit id: "2-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch1 | ||||||
|  |         branch branch2 | ||||||
|  |         commit id: "3-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch2 | ||||||
|  |         branch branch3 | ||||||
|  |         commit id: "4-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch3 | ||||||
|  |         branch branch4 | ||||||
|  |         commit id: "5-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch4 | ||||||
|  |         branch branch5 | ||||||
|  |         commit id: "6-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch5 | ||||||
|  |         branch branch6 | ||||||
|  |         commit id: "7-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch6 | ||||||
|  |         branch branch7 | ||||||
|  |         commit id: "8-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch7 | ||||||
|  |         branch branch8 | ||||||
|  |         commit id: "9-abcdefg" | ||||||
|  |         switch main | ||||||
|  |         merge branch8 | ||||||
|  |         branch branch9 | ||||||
|  |         commit id: "10-abcdefg" | ||||||
|  |         `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										36
									
								
								cypress/integration/rendering/katex.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								cypress/integration/rendering/katex.spec.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | import { imgSnapshotTest } from '../../helpers/util'; | ||||||
|  |  | ||||||
|  | describe('Katex', () => { | ||||||
|  |   it('1: should render a complex Katex flowchart no htmlLabels', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `graph LR | ||||||
|  |       A["$$f(\\relax{x}) = \\int_{-\\infty}^\\infty \\hat{f}(\\xi)\\,e^{2 \\pi i \\xi x}\\,d\\xi$$"] -->|"$$\\Bigg(\\bigg(\\Big(\\big((\\frac{-b\\pm\\sqrt{b^2-4ac}}{2a})\\big)\\Big)\\bigg)\\Bigg)$$"| B("$$1+\\frac{e^{-2\\pi}} {1+\\frac{e^{-4\\pi}} {1+\\frac{e^{-6\\pi}} {1+\\frac{e^{-8\\pi}} {1+\\cdots}}}}$$") | ||||||
|  |       A -->|"$$\\overbrace{a+b+c}^{\\text{note}}$$"| C("$$\\phase{-78^\\circ}$$") | ||||||
|  |       B --> D("$$x = \\begin{cases} a &\\text{if } b \\\\ c &\\text{if } d \\end{cases}$$") | ||||||
|  |       C --> E("$$x(t)=c_1\\begin{bmatrix}-\\cos{t}+\\sin{t}\\\\ 2\\cos{t} \\end{bmatrix}e^{2t}$$")`, | ||||||
|  |       { fontFamily: 'courier' } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('2: should render a Katex flowchart containing the Greek alphabet', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `graph LR | ||||||
|  |       A["$$\\alpha\\beta\\gamma\\delta\\epsilon\\zeta\\eta\\theta\\iota\\kappa\\lambda\\mu\\nu\\xi\\omicron\\pi\\rho\\sigma\\tau\\upsilon\\phi\\chi\\psi\\omega$$"] --> B["$$\\Alpha\\Beta\\Gamma\\Delta\\Epsilon\\Zeta\\Eta\\Theta\\Iota\\Kappa\\Lambda\\Mu\\Nu\\Xi\\Omicron\\Pi\\Rho\\Sigma\\Tau\\Upsilon\\Phi\\Chi\\Psi\\Omega$$"]`, | ||||||
|  |       { fontFamily: 'courier' } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   it('3: should render a Katex flowchart containing set theory symbols', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `graph LR | ||||||
|  |       A["$$\\forall\\complement\\therefore\\emptyset\\exists\\subset\\because\\empty\\exist\\supset\\mapsto\\varnothing\\nexists\\mid\\to\\implies\\in\\land\\gets\\impliedby\\isin\\lor\\leftrightarrow\\iff\\notin\\ni\\notni\\lnot$$"] --> B["$$\\nabla\\Im\\Reals\\jmath\\partial\\image\\wp\\aleph\\Game\\weierp\\alef\\Finv\\N\\Z\\alefsym\\cnums\\natnums\\beth\\Complex\\R\\gimel\\ell\\Re\\daleth\\hbar\\real\\eth\\hslash\\reals$$"]`, | ||||||
|  |       { fontFamily: 'courier' } | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |   // TODO: changes made to develop between Feb 13 - Feb 23 cause this test to no longer function | ||||||
|  |   // it.skip('4: should render an error box originating from Katex', () => { | ||||||
|  |   //   imgSnapshotTest( | ||||||
|  |   //     `graph LR | ||||||
|  |   //     A["$$\\shouldBeError$$"]`, | ||||||
|  |   //     { fontFamily: 'courier' } | ||||||
|  |   //   ); | ||||||
|  |   // }); | ||||||
|  | }); | ||||||
							
								
								
									
										67
									
								
								cypress/integration/rendering/packet.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								cypress/integration/rendering/packet.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | import { imgSnapshotTest } from '../../helpers/util'; | ||||||
|  |  | ||||||
|  | describe('packet structure', () => { | ||||||
|  |   it('should render a simple packet diagram', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `packet-beta | ||||||
|  |   title Hello world | ||||||
|  |   0-10: "hello" | ||||||
|  | ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('should render a complex packet diagram', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       `packet-beta | ||||||
|  |         0-15: "Source Port" | ||||||
|  |         16-31: "Destination Port" | ||||||
|  |         32-63: "Sequence Number" | ||||||
|  |         64-95: "Acknowledgment Number" | ||||||
|  |         96-99: "Data Offset" | ||||||
|  |         100-105: "Reserved" | ||||||
|  |         106: "URG" | ||||||
|  |         107: "ACK" | ||||||
|  |         108: "PSH" | ||||||
|  |         109: "RST" | ||||||
|  |         110: "SYN" | ||||||
|  |         111: "FIN" | ||||||
|  |         112-127: "Window" | ||||||
|  |         128-143: "Checksum" | ||||||
|  |         144-159: "Urgent Pointer" | ||||||
|  |         160-191: "(Options and Padding)" | ||||||
|  |         192-223: "data" | ||||||
|  |       ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('should render a complex packet diagram with showBits false', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |       --- | ||||||
|  |       title: "Packet Diagram" | ||||||
|  |       config: | ||||||
|  |         packet: | ||||||
|  |           showBits: false | ||||||
|  |       --- | ||||||
|  |       packet-beta | ||||||
|  |         0-15: "Source Port" | ||||||
|  |         16-31: "Destination Port" | ||||||
|  |         32-63: "Sequence Number" | ||||||
|  |         64-95: "Acknowledgment Number" | ||||||
|  |         96-99: "Data Offset" | ||||||
|  |         100-105: "Reserved" | ||||||
|  |         106: "URG" | ||||||
|  |         107: "ACK" | ||||||
|  |         108: "PSH" | ||||||
|  |         109: "RST" | ||||||
|  |         110: "SYN" | ||||||
|  |         111: "FIN" | ||||||
|  |         112-127: "Window" | ||||||
|  |         128-143: "Checksum" | ||||||
|  |         144-159: "Urgent Pointer" | ||||||
|  |         160-191: "(Options and Padding)" | ||||||
|  |         192-223: "data" | ||||||
|  |       ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| import { imgSnapshotTest, renderGraph } from '../../helpers/util.ts'; | import { imgSnapshotTest } from '../../helpers/util.ts'; | ||||||
|  |  | ||||||
| describe('Quadrant Chart', () => { | describe('Quadrant Chart', () => { | ||||||
|   it('should render if only chart type is provided', () => { |   it('should render if only chart type is provided', () => { | ||||||
| @@ -226,4 +226,52 @@ describe('Quadrant Chart', () => { | |||||||
|     ); |     ); | ||||||
|     cy.get('svg'); |     cy.get('svg'); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|  |   it('it should render data points with styles', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |   quadrantChart | ||||||
|  |     title Reach and engagement of campaigns | ||||||
|  |     x-axis Reach --> | ||||||
|  |     y-axis Engagement --> | ||||||
|  |     quadrant-1 We should expand | ||||||
|  |     quadrant-2 Need to promote | ||||||
|  |     quadrant-3 Re-evaluate | ||||||
|  |     quadrant-4 May be improved | ||||||
|  |     Campaign A: [0.3, 0.6] radius: 20 | ||||||
|  |     Campaign B: [0.45, 0.23]     color: #ff0000   | ||||||
|  |     Campaign C: [0.57, 0.69]  stroke-color: #ff00ff   | ||||||
|  |     Campaign D: [0.78, 0.34]        stroke-width: 3px     | ||||||
|  |     Campaign E: [0.40, 0.34] radius: 20,   color: #ff0000  , stroke-color  : #ff00ff,     stroke-width    :   3px    | ||||||
|  |     Campaign F: [0.35, 0.78] stroke-width: 3px , color: #ff0000, radius: 20, stroke-color:     #ff00ff | ||||||
|  |     Campaign G: [0.22, 0.22] stroke-width: 3px  , color: #309708  ,  radius  : 20  ,  stroke-color:    #5060ff | ||||||
|  |     Campaign H: [0.22, 0.44] | ||||||
|  |       `, | ||||||
|  |       {} | ||||||
|  |     ); | ||||||
|  |     cy.get('svg'); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('it should render data points with styles + classes', () => { | ||||||
|  |     imgSnapshotTest( | ||||||
|  |       ` | ||||||
|  |   quadrantChart | ||||||
|  |     title Reach and engagement of campaigns | ||||||
|  |     x-axis Reach --> | ||||||
|  |     y-axis Engagement --> | ||||||
|  |     quadrant-1 We should expand | ||||||
|  |     quadrant-2 Need to promote | ||||||
|  |     quadrant-3 Re-evaluate | ||||||
|  |     quadrant-4 May be improved | ||||||
|  |     Campaign A:::class1: [0.3, 0.6] radius: 20 | ||||||
|  |     Campaign B: [0.45, 0.23] color: #ff0000 | ||||||
|  |     Campaign C: [0.57, 0.69] stroke-color: #ff00ff | ||||||
|  |     Campaign D:::class2: [0.78, 0.34] stroke-width: 3px | ||||||
|  |     Campaign E:::class2: [0.40, 0.34] radius: 20, color: #ff0000, stroke-color: #ff00ff, stroke-width: 3px | ||||||
|  |     Campaign F:::class1: [0.35, 0.78] | ||||||
|  |     classDef class1 color: #908342, radius : 10, stroke-color: #310085, stroke-width: 10px | ||||||
|  |     classDef class2 color: #f00fff, radius : 10 | ||||||
|  |     ` | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -375,6 +375,29 @@ context('Sequence diagram', () => { | |||||||
|         {} |         {} | ||||||
|       ); |       ); | ||||||
|     }); |     }); | ||||||
|  |     it('should have actor-top and actor-bottom classes on top and bottom actor box and symbol and actor-box and actor-man classes for text tags', () => { | ||||||
|  |       imgSnapshotTest( | ||||||
|  |         ` | ||||||
|  |         sequenceDiagram | ||||||
|  |           actor Bob | ||||||
|  |           Alice->>Bob: Hi Bob | ||||||
|  |           Bob->>Alice: Hi Alice | ||||||
|  |       `, | ||||||
|  |         {} | ||||||
|  |       ); | ||||||
|  |       cy.get('.actor').should('have.class', 'actor-top'); | ||||||
|  |       cy.get('.actor-man').should('have.class', 'actor-top'); | ||||||
|  |       cy.get('.actor.actor-top').should('not.have.class', 'actor-bottom'); | ||||||
|  |       cy.get('.actor-man.actor-top').should('not.have.class', 'actor-bottom'); | ||||||
|  |  | ||||||
|  |       cy.get('.actor').should('have.class', 'actor-bottom'); | ||||||
|  |       cy.get('.actor-man').should('have.class', 'actor-bottom'); | ||||||
|  |       cy.get('.actor.actor-bottom').should('not.have.class', 'actor-top'); | ||||||
|  |       cy.get('.actor-man.actor-bottom').should('not.have.class', 'actor-top'); | ||||||
|  |  | ||||||
|  |       cy.get('text.actor-box').should('include.text', 'Alice'); | ||||||
|  |       cy.get('text.actor-man').should('include.text', 'Bob'); | ||||||
|  |     }); | ||||||
|     it('should render long notes left of actor', () => { |     it('should render long notes left of actor', () => { | ||||||
|       imgSnapshotTest( |       imgSnapshotTest( | ||||||
|         ` |         ` | ||||||
| @@ -787,11 +810,42 @@ context('Sequence diagram', () => { | |||||||
|         note left of Alice: config: mirrorActors=true<br/>directive: mirrorActors=false |         note left of Alice: config: mirrorActors=true<br/>directive: mirrorActors=false | ||||||
|         Bob->>Alice: Short as well |         Bob->>Alice: Short as well | ||||||
|       `, |       `, | ||||||
|         { logLevel: 0, sequence: { mirrorActors: true, noteFontSize: 18, noteFontFamily: 'Arial' } } |         { | ||||||
|  |           logLevel: 0, | ||||||
|  |           sequence: { mirrorActors: true, noteFontSize: 18, noteFontFamily: 'Arial' }, | ||||||
|  |         } | ||||||
|       ); |       ); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|   context('links', () => { |   context('links', () => { | ||||||
|  |     it('should support actor links', () => { | ||||||
|  |       renderGraph( | ||||||
|  |         ` | ||||||
|  |       sequenceDiagram | ||||||
|  |         link Alice: Dashboard @ https://dashboard.contoso.com/alice | ||||||
|  |         link Alice: Wiki @ https://wiki.contoso.com/alice | ||||||
|  |         link John: Dashboard @ https://dashboard.contoso.com/john | ||||||
|  |         link John: Wiki @ https://wiki.contoso.com/john | ||||||
|  |         Alice->>John: Hello John<br/> | ||||||
|  |         John-->>Alice: Great<br/><br/>day! | ||||||
|  |       `, | ||||||
|  |         { securityLevel: 'loose' } | ||||||
|  |       ); | ||||||
|  |       cy.get('#actor0_popup').should((popupMenu) => { | ||||||
|  |         const style = popupMenu.attr('style'); | ||||||
|  |         expect(style).to.undefined; | ||||||
|  |       }); | ||||||
|  |       cy.get('#root-0').click(); | ||||||
|  |       cy.get('#actor0_popup').should((popupMenu) => { | ||||||
|  |         const style = popupMenu.attr('style'); | ||||||
|  |         expect(style).to.match(/^display: block;$/); | ||||||
|  |       }); | ||||||
|  |       cy.get('#root-0').click(); | ||||||
|  |       cy.get('#actor0_popup').should((popupMenu) => { | ||||||
|  |         const style = popupMenu.attr('style'); | ||||||
|  |         expect(style).to.match(/^display: none;$/); | ||||||
|  |       }); | ||||||
|  |     }); | ||||||
|     it('should support actor links and properties EXPERIMENTAL: USE WITH CAUTION', () => { |     it('should support actor links and properties EXPERIMENTAL: USE WITH CAUTION', () => { | ||||||
|       //Be aware that the syntax for "properties" is likely to be changed. |       //Be aware that the syntax for "properties" is likely to be changed. | ||||||
|       imgSnapshotTest( |       imgSnapshotTest( | ||||||
| @@ -810,7 +864,10 @@ context('Sequence diagram', () => { | |||||||
|         a->>j: Hello John, how are you? |         a->>j: Hello John, how are you? | ||||||
|         j-->>a: Great! |         j-->>a: Great! | ||||||
|       `, |       `, | ||||||
|         { logLevel: 0, sequence: { mirrorActors: true, noteFontSize: 18, noteFontFamily: 'Arial' } } |         { | ||||||
|  |           logLevel: 0, | ||||||
|  |           sequence: { mirrorActors: true, noteFontSize: 18, noteFontFamily: 'Arial' }, | ||||||
|  |         } | ||||||
|       ); |       ); | ||||||
|     }); |     }); | ||||||
|     it('should support actor links and properties when not mirrored EXPERIMENTAL: USE WITH CAUTION', () => { |     it('should support actor links and properties when not mirrored EXPERIMENTAL: USE WITH CAUTION', () => { | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> |     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> | ||||||
|     <link |     <link | ||||||
|       rel="stylesheet" |       rel="stylesheet" | ||||||
|       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" |       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/font-awesome.min.css" | ||||||
|     /> |     /> | ||||||
|     <link |     <link | ||||||
|       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" | ||||||
| @@ -33,7 +33,9 @@ | |||||||
|         background-image: radial-gradient(#fff 1%, transparent 11%), |         background-image: radial-gradient(#fff 1%, transparent 11%), | ||||||
|           radial-gradient(#fff 1%, transparent 11%); |           radial-gradient(#fff 1%, transparent 11%); | ||||||
|         background-size: 20px 20px; |         background-size: 20px 20px; | ||||||
|         background-position: 0 0, 10px 10px; |         background-position: | ||||||
|  |           0 0, | ||||||
|  |           10px 10px; | ||||||
|         background-repeat: repeat; |         background-repeat: repeat; | ||||||
|       } |       } | ||||||
|       .malware { |       .malware { | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
|     <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" /> |     <link href="https://fonts.googleapis.com/css?family=Montserrat&display=swap" rel="stylesheet" /> | ||||||
|     <link |     <link | ||||||
|       rel="stylesheet" |       rel="stylesheet" | ||||||
|       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" |       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/font-awesome.min.css" | ||||||
|     /> |     /> | ||||||
|     <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" | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> |     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> | ||||||
|     <link |     <link | ||||||
|       rel="stylesheet" |       rel="stylesheet" | ||||||
|       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" |       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/font-awesome.min.css" | ||||||
|     /> |     /> | ||||||
|     <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" | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> |     <link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet" /> | ||||||
|     <link |     <link | ||||||
|       rel="stylesheet" |       rel="stylesheet" | ||||||
|       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" |       href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/font-awesome.min.css" | ||||||
|     /> |     /> | ||||||
|     <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" | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| <html> | <html> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="utf-8" /> |     <meta charset="utf-8" /> | ||||||
|     <script src="./viewer.js" type="module"></script> |     <script type="module" src="./viewer.js"></script> | ||||||
|     <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" | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| <!DOCTYPE html> | <!doctype html> | ||||||
| <html lang="en"> | <html lang="en"> | ||||||
|   <head> |   <head> | ||||||
|     <meta charset="UTF-8" /> |     <meta charset="UTF-8" /> | ||||||
|   | |||||||
| @@ -11,8 +11,7 @@ example-diagram | |||||||
|     <!-- <script src="//cdn.jsdelivr.net/npm/mermaid@9.1.7/dist/mermaid.min.js"></script> --> |     <!-- <script src="//cdn.jsdelivr.net/npm/mermaid@9.1.7/dist/mermaid.min.js"></script> --> | ||||||
|     <!-- <script type="module" src="./external-diagrams-mindmap.mjs" /> --> |     <!-- <script type="module" src="./external-diagrams-mindmap.mjs" /> --> | ||||||
|     <script type="module"> |     <script type="module"> | ||||||
|       import exampleDiagram from '../../packages/mermaid-example-diagram/dist/mermaid-example-diagram.core.mjs'; |       import exampleDiagram from './mermaid-example-diagram.esm.mjs'; | ||||||
|       // import example from '../../packages/mermaid-example-diagram/src/detector'; |  | ||||||
|       import mermaid from './mermaid.esm.mjs'; |       import mermaid from './mermaid.esm.mjs'; | ||||||
|  |  | ||||||
|       await mermaid.registerExternalDiagrams([exampleDiagram]); |       await mermaid.registerExternalDiagrams([exampleDiagram]); | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user