mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-25 00:44:10 +02:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			renovate/n
			...
			7079-c4con
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 835de0012d | 
| @@ -1,5 +0,0 @@ | ||||
| --- | ||||
| 'mermaid': patch | ||||
| --- | ||||
|  | ||||
| fix: Correct viewBox casing and make SVGs responsive | ||||
							
								
								
									
										5
									
								
								.changeset/ten-plums-bet.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.changeset/ten-plums-bet.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| --- | ||||
| 'mermaid': patch | ||||
| --- | ||||
|  | ||||
| fix: Support ComponentQueue_Ext to prevent parsing error | ||||
| @@ -99,7 +99,6 @@ export const openURLAndVerifyRendering = ( | ||||
|   cy.visit(url); | ||||
|   cy.window().should('have.property', 'rendered', true); | ||||
|   cy.get('svg').should('be.visible'); | ||||
|   cy.get('svg').should('not.have.attr', 'viewbox'); | ||||
|  | ||||
|   if (validation) { | ||||
|     cy.get('svg').should(validation); | ||||
|   | ||||
| @@ -21,7 +21,7 @@ title: Animal example | ||||
| classDiagram | ||||
|     note "From Duck till Zebra" | ||||
|     Animal <|-- Duck | ||||
|     note for Duck "can fly<br>can swim<br>can dive<br>can help in debugging" | ||||
|     note for Duck "can fly\ncan swim\ncan dive\ncan help in debugging" | ||||
|     Animal <|-- Fish | ||||
|     Animal <|-- Zebra | ||||
|     Animal : +int age | ||||
| @@ -50,7 +50,7 @@ title: Animal example | ||||
| classDiagram | ||||
|     note "From Duck till Zebra" | ||||
|     Animal <|-- Duck | ||||
|     note for Duck "can fly<br>can swim<br>can dive<br>can help in debugging" | ||||
|     note for Duck "can fly\ncan swim\ncan dive\ncan help in debugging" | ||||
|     Animal <|-- Fish | ||||
|     Animal <|-- Zebra | ||||
|     Animal : +int age | ||||
|   | ||||
							
								
								
									
										58
									
								
								packages/mermaid/src/diagrams/c4/parser/c4Component.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								packages/mermaid/src/diagrams/c4/parser/c4Component.spec.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| import c4Db from '../c4Db.js'; | ||||
| import c4 from './c4Diagram.jison'; | ||||
| import { setConfig } from '../../../config.js'; | ||||
|  | ||||
| setConfig({ | ||||
|   securityLevel: 'strict', | ||||
| }); | ||||
|  | ||||
| describe.each([ | ||||
|   ['Component', 'component'], | ||||
|   ['ComponentDb', 'component_db'], | ||||
|   ['ComponentQueue', 'component_queue'], | ||||
|   ['Component_Ext', 'external_component'], | ||||
|   ['ComponentDb_Ext', 'external_component_db'], | ||||
|   ['ComponentQueue_Ext', 'external_component_queue'], | ||||
| ])('parsing a C4 %s', function (macroName, elementName) { | ||||
|   beforeEach(function () { | ||||
|     c4.parser.yy = c4Db; | ||||
|     c4.parser.yy.clear(); | ||||
|   }); | ||||
|  | ||||
|   it('should parse a C4 diagram with one Component correctly', function () { | ||||
|     c4.parser.parse(`C4Component | ||||
| title Component diagram for Internet Banking Component | ||||
| ${macroName}(ComponentAA, "Internet Banking Component", "Technology", "Allows customers to view information about their bank accounts, and make payments.")`); | ||||
|  | ||||
|     const yy = c4.parser.yy; | ||||
|  | ||||
|     const shapes = yy.getC4ShapeArray(); | ||||
|     expect(shapes.length).toBe(1); | ||||
|     const onlyShape = shapes[0]; | ||||
|  | ||||
|     expect(onlyShape).toMatchObject({ | ||||
|       alias: 'ComponentAA', | ||||
|       descr: { | ||||
|         text: 'Allows customers to view information about their bank accounts, and make payments.', | ||||
|       }, | ||||
|       label: { | ||||
|         text: 'Internet Banking Component', | ||||
|       }, | ||||
|       techn: { | ||||
|         text: 'Technology', | ||||
|       }, | ||||
|       typeC4Shape: { | ||||
|         text: elementName, | ||||
|       }, | ||||
|     }); | ||||
|   }); | ||||
|  | ||||
|   it('should handle a trailing whitespaces after Component', function () { | ||||
|     const whitespace = ' '; | ||||
|     const rendered = c4.parser.parse(`C4Component${whitespace} | ||||
| title Component diagram for Internet Banking Component${whitespace} | ||||
| ${macroName}(ComponentAA, "Internet Banking Component", "Technology", "Allows customers to view information about their bank accounts, and make payments.")${whitespace}`); | ||||
|  | ||||
|     expect(rendered).toBe(true); | ||||
|   }); | ||||
| }); | ||||
| @@ -158,10 +158,10 @@ accDescr\s*"{"\s*                         { this.begin("acc_descr_multiline");} | ||||
| "UpdateRelStyle"                          { this.begin("update_rel_style"); return 'UPDATE_REL_STYLE';} | ||||
| "UpdateLayoutConfig"                      { this.begin("update_layout_config"); return 'UPDATE_LAYOUT_CONFIG';} | ||||
|  | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config><<EOF>>                return "EOF_IN_STRUCT"; | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config>[(][ ]*[,]             { this.begin("attribute"); return "ATTRIBUTE_EMPTY";} | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config>[(]                    { this.begin("attribute"); } | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config,attribute>[)]          { this.popState();this.popState();} | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext_queue,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config><<EOF>>                return "EOF_IN_STRUCT"; | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext_queue,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config>[(][ ]*[,]             { this.begin("attribute"); return "ATTRIBUTE_EMPTY";} | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext_queue,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config>[(]                    { this.begin("attribute"); } | ||||
| <person,person_ext,system_ext_queue,system_ext_db,system_ext,system_queue,system_db,system,boundary,enterprise_boundary,system_boundary,container_ext_db,container_ext_queue,container_ext,container_queue,container_db,container,container_boundary,component_ext_db,component_ext_queue,component_ext,component_queue,component_db,component,node,node_l,node_r,rel,birel,rel_u,rel_d,rel_l,rel_r,rel_b,rel_index,update_el_style,update_rel_style,update_layout_config,attribute>[)]          { this.popState();this.popState();} | ||||
|  | ||||
| <attribute>",,"                           { return 'ATTRIBUTE_EMPTY';} | ||||
| <attribute>","                            { } | ||||
|   | ||||
| @@ -16,7 +16,7 @@ const draw: DrawDefinition = (_text, id, _version, diagram: Diagram) => { | ||||
|   const svgWidth = bitWidth * bitsPerRow + 2; | ||||
|   const svg: SVG = selectSvgElement(id); | ||||
|  | ||||
|   svg.attr('viewBox', `0 0 ${svgWidth} ${svgHeight}`); | ||||
|   svg.attr('viewbox', `0 0 ${svgWidth} ${svgHeight}`); | ||||
|   configureSvgSize(svg, svgHeight, svgWidth, config.useMaxWidth); | ||||
|  | ||||
|   for (const [word, packet] of words.entries()) { | ||||
|   | ||||
| @@ -2,7 +2,6 @@ import type { Diagram } from '../../Diagram.js'; | ||||
| import type { RadarDiagramConfig } from '../../config.type.js'; | ||||
| import type { DiagramRenderer, DrawDefinition, SVG, SVGGroup } from '../../diagram-api/types.js'; | ||||
| import { selectSvgElement } from '../../rendering-util/selectSvgElement.js'; | ||||
| import { configureSvgSize } from '../../setupGraphViewbox.js'; | ||||
| import type { RadarDB, RadarAxis, RadarCurve } from './types.js'; | ||||
|  | ||||
| const draw: DrawDefinition = (_text, id, _version, diagram: Diagram) => { | ||||
| @@ -54,9 +53,11 @@ const drawFrame = (svg: SVG, config: Required<RadarDiagramConfig>): SVGGroup => | ||||
|     x: config.marginLeft + config.width / 2, | ||||
|     y: config.marginTop + config.height / 2, | ||||
|   }; | ||||
|   configureSvgSize(svg, totalHeight, totalWidth, config.useMaxWidth ?? true); | ||||
|  | ||||
|   svg.attr('viewBox', `0 0 ${totalWidth} ${totalHeight}`); | ||||
|   // Initialize the SVG | ||||
|   svg | ||||
|     .attr('viewbox', `0 0 ${totalWidth} ${totalHeight}`) | ||||
|     .attr('width', totalWidth) | ||||
|     .attr('height', totalHeight); | ||||
|   // g element to center the radar chart | ||||
|   return svg.append('g').attr('transform', `translate(${center.x}, ${center.y})`); | ||||
| }; | ||||
|   | ||||
| @@ -15,7 +15,7 @@ title: Animal example | ||||
| classDiagram | ||||
|     note "From Duck till Zebra" | ||||
|     Animal <|-- Duck | ||||
|     note for Duck "can fly<br>can swim<br>can dive<br>can help in debugging" | ||||
|     note for Duck "can fly\ncan swim\ncan dive\ncan help in debugging" | ||||
|     Animal <|-- Fish | ||||
|     Animal <|-- Zebra | ||||
|     Animal : +int age | ||||
|   | ||||
							
								
								
									
										674
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										674
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user