{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "web_app_architecture_01"
  },
  "global_properties": {
    "topic": "Web Application System Architecture",
    "purpose": "architecture_overview",
    "target_audience": "engineer",
    "complexity_level": "publication_quality",
    "domain": "Computer Science",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "3-tier_vertical",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "",
      "is_present": false
    }
  },
  "components": [
    {
      "id": "c1",
      "type": "group_container",
      "label": "Frontend",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F9F9C5",
        "border_color": "#003366",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c1a",
      "type": "shape_node",
      "label": "Vue",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c1b",
      "type": "shape_node",
      "label": "CSS",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c1c",
      "type": "shape_node",
      "label": "HTML",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c1d",
      "type": "shape_node",
      "label": "...",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c1e",
      "type": "shape_node",
      "label": "ECharts",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c2",
      "type": "group_container",
      "label": "Interaction",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F9F9C5",
        "border_color": "#003366",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c2a",
      "type": "shape_node",
      "label": "View Router",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c2b",
      "type": "shape_node",
      "label": "Axios",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#BFE3F7",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c2c",
      "type": "shape_node",
      "label": "Post",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c2d",
      "type": "shape_node",
      "label": "Get",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3",
      "type": "group_container",
      "label": "Backend",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F9F9C5",
        "border_color": "#003366",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c3a",
      "type": "shape_node",
      "label": "View Layer",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#BFE3F7",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3b",
      "type": "group_container",
      "label": "Business Logic Layer",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#BFE3F7",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3b1",
      "type": "shape_node",
      "label": "Data Download",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3b2",
      "type": "group_container",
      "label": "Spark",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#D3D3D3",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3b2a",
      "type": "shape_node",
      "label": "Data Preprocess",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3b3",
      "type": "group_container",
      "label": "AI",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#F9D9D9",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3b3a",
      "type": "shape_node",
      "label": "Prediction",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c3c",
      "type": "shape_node",
      "label": "Data Access Layer",
      "geometry": {
        "shape": "rectangle"
      },
      "styling": {
        "fill_color": "#BFE3F7",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c4",
      "type": "group_container",
      "label": "Data Storage",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#F9F9C5",
        "border_color": "#003366",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "bold",
        "text_color": "#000000"
      }
    },
    {
      "id": "c4a",
      "type": "shape_node",
      "label": "MySQL",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    },
    {
      "id": "c4b",
      "type": "shape_node",
      "label": "Apache Hadoop",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#DFF2D8",
        "border_color": "#003366",
        "border_width": 1,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#222222"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "c1",
      "to_id": "c2",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#003366",
        "width": 4
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    },
    {
      "id": "conn2",
      "from_id": "c2",
      "to_id": "c3",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#003366",
        "width": 4
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    },
    {
      "id": "conn3",
      "from_id": "c3",
      "to_id": "c4",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#003366",
        "width": 4
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    },
    {
      "id": "conn4",
      "from_id": "c4",
      "to_id": "c3",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#003366",
        "width": 4
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    },
    {
      "id": "conn5",
      "from_id": "c2",
      "to_id": "c1",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#003366",
        "width": 4
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "large"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "c1",
      "element_ids": [
        "c1a",
        "c1b",
        "c1c",
        "c1d",
        "c1e"
      ],
      "padding": "medium"
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c1a",
        "c1b",
        "c1c",
        "c1d",
        "c1e"
      ]
    },
    {
      "type": "containment",
      "container_id": "c2",
      "element_ids": [
        "c2a",
        "c2b",
        "c2c",
        "c2d"
      ],
      "padding": "medium"
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c2a",
        "c2b",
        "c2c",
        "c2d"
      ]
    },
    {
      "type": "containment",
      "container_id": "c3",
      "element_ids": [
        "c3a",
        "c3b",
        "c3c"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "c3b",
      "element_ids": [
        "c3b1",
        "c3b2",
        "c3b3"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "c3b2",
      "element_ids": [
        "c3b2a"
      ],
      "padding": "small"
    },
    {
      "type": "containment",
      "container_id": "c3b3",
      "element_ids": [
        "c3b3a"
      ],
      "padding": "small"
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c3b1",
        "c3b2",
        "c3b3"
      ]
    },
    {
      "type": "containment",
      "container_id": "c4",
      "element_ids": [
        "c4a",
        "c4b"
      ],
      "padding": "medium"
    },
    {
      "type": "distribution",
      "distribution_type": "horizontal_equal_spacing",
      "element_ids": [
        "c4a",
        "c4b"
      ]
    },
    {
      "type": "distribution",
      "distribution_type": "vertical_equal_spacing",
      "element_ids": [
        "c1",
        "c2",
        "c3",
        "c4"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "c1",
        "c2",
        "c3",
        "c4"
      ]
    }
  ]
}