{
  "name": "image-upload-preview",
  "kind": "block",
  "primary": "section",
  "page": "/catalog/ui-patterns/v050-mode-c-blocks/v050-mode-c-blocks.contents.html",
  "slots": [],
  "nested": [],
  "attrs": {},
  "html": "<section>\n    <field-ui label=\"Profile picture\" hint=\"JPG or PNG, max 2MB\">\n      <col-ui gap=\"3\">\n        <row-ui gap=\"3\" align=\"center\">\n          <avatar-ui text=\"JS\" size=\"xl\"></avatar-ui>\n          <col-ui gap=\"1\">\n            <text-ui strong size=\"sm\">profile-current.jpg</text-ui>\n            <text-ui size=\"sm\" color=\"subtle\">128 × 128 · 84 KB</text-ui>\n          </col-ui>\n        </row-ui>\n        <row-ui gap=\"2\">\n          <button-ui text=\"Replace\" variant=\"outline\" size=\"sm\" icon=\"upload\"></button-ui>\n          <button-ui text=\"Remove\" variant=\"ghost\" size=\"sm\" icon=\"trash\"></button-ui>\n        </row-ui>\n      </col-ui>\n    </field-ui>\n  </section>",
  "source": "catalog/ui-patterns/v050-mode-c-blocks/v050-mode-c-blocks.contents.html",
  "metadata": {
    "domain": "forms",
    "description": "Image upload with preview thumbnail, file metadata, and replace/remove actions.",
    "keywords": [
      "image",
      "upload",
      "preview",
      "avatar",
      "profile-picture",
      "file-input",
      "drag-drop",
      "replace",
      "remove"
    ]
  },
  "captured_at": "2026-06-07T19:28:13.657Z",
  "template": [
    {
      "id": "avatar",
      "component": "Avatar",
      "size": "xl",
      "text": "JS"
    },
    {
      "id": "text",
      "component": "Text",
      "size": "sm",
      "strong": true,
      "textContent": "profile-current.jpg"
    },
    {
      "id": "text-2",
      "component": "Text",
      "color": "subtle",
      "size": "sm",
      "textContent": "128 × 128 · 84 KB"
    },
    {
      "id": "column-2",
      "component": "Column",
      "gap": "1",
      "children": [
        "text",
        "text-2"
      ]
    },
    {
      "id": "row",
      "component": "Row",
      "align": "center",
      "gap": "3",
      "children": [
        "avatar",
        "column-2"
      ]
    },
    {
      "id": "button",
      "component": "Button",
      "icon": "upload",
      "size": "sm",
      "text": "Replace",
      "variant": "outline"
    },
    {
      "id": "button-2",
      "component": "Button",
      "icon": "trash",
      "size": "sm",
      "text": "Remove",
      "variant": "ghost"
    },
    {
      "id": "row-2",
      "component": "Row",
      "gap": "2",
      "children": [
        "button",
        "button-2"
      ]
    },
    {
      "id": "column",
      "component": "Column",
      "gap": "3",
      "children": [
        "row",
        "row-2"
      ]
    },
    {
      "id": "field",
      "component": "Field",
      "hint": "JPG or PNG, max 2MB",
      "label": "Profile picture",
      "children": [
        "column"
      ]
    },
    {
      "id": "root",
      "component": "Section",
      "children": [
        "field"
      ]
    }
  ]
}
