)]}'
{
  "log": [
    {
      "commit": "72682df0c3aa2e2b8917d0f66bdf8988dfbcb59f",
      "tree": "b5c213237eced535db85dc8906fa42127bd525f0",
      "parents": [
        "4de80d219b96677b9e43e50293ec55bdf273f36d"
      ],
      "author": {
        "name": "Philip Zeyliger",
        "email": "philip.zeyliger@gmail.com",
        "time": "Wed Apr 23 13:09:46 2025 -0700"
      },
      "committer": {
        "name": "Philip Zeyliger",
        "email": "philip.zeyliger@gmail.com",
        "time": "Wed Apr 23 13:09:46 2025 -0700"
      },
      "message": "Prettier.\n"
    },
    {
      "commit": "9a66cad2e538c0edd4b973332f8e3e6d3a5763ef",
      "tree": "2dabe16fa6608b3bbe23fc20189d83d3f1039b7b",
      "parents": [
        "10a7ac13a8aac36d947de8824452814596eb1dde"
      ],
      "author": {
        "name": "Philip Zeyliger",
        "email": "philip.zeyliger@gmail.com",
        "time": "Wed Apr 23 12:21:40 2025 -0700"
      },
      "committer": {
        "name": "Philip Zeyliger",
        "email": "philip.zeyliger@gmail.com",
        "time": "Wed Apr 23 12:25:04 2025 -0700"
      },
      "message": "sketch: simplify sketch-chat-input and diff comment handling\n\nIt seems like the top-level property in sketch-app-shell is enough\nfor the chat input, and we can just use that.\n"
    },
    {
      "commit": "10a7ac13a8aac36d947de8824452814596eb1dde",
      "tree": "58bb570782fa0dc026e4653874373d8dd0653c83",
      "parents": [
        "af2d7e3940d063e4e5dfed2abed69c698f9b04fc"
      ],
      "author": {
        "name": "Philip Zeyliger",
        "email": "philip.zeyliger@gmail.com",
        "time": "Wed Apr 23 11:56:03 2025 -0700"
      },
      "committer": {
        "name": "Philip Zeyliger",
        "email": "philip.zeyliger@gmail.com",
        "time": "Wed Apr 23 12:12:36 2025 -0700"
      },
      "message": "Fix chat input resize test by waiting for animation frame\n\nThe test was checking the height of the textarea immediately after filling\nit with content, but the component uses requestAnimationFrame() to adjust\nthe height asynchronously. Added a wait for the animation frame to complete\nbefore checking the height.\n\nCo-Authored-By: sketch\n"
    },
    {
      "commit": "5164eee229bec08f6ba01d6416a4e0c324230c5a",
      "tree": "a7948033c06853104f35cd013fb4b2ddcaf760dd",
      "parents": [
        "2deac8429a5364866ab6471b44466f78ccf5c0b3"
      ],
      "author": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Mon Apr 21 18:20:23 2025 -0700"
      },
      "committer": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Mon Apr 21 18:20:23 2025 -0700"
      },
      "message": "webui: run format, ignore src/types.ts\n"
    },
    {
      "commit": "07b3e39ebe648f91f02a9cb703ecbc49900c91da",
      "tree": "7c49f8f8b7ab1d5086e4fa777534f6aedc793e93",
      "parents": [
        "8a89e1cbd3e7c9bbe1c561e88141527a0c894e06"
      ],
      "author": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Mon Apr 21 22:51:14 2025 +0000"
      },
      "committer": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Mon Apr 21 16:57:08 2025 -0700"
      },
      "message": "Make textarea in sketch-chat-input user-resizable\n\nFixes https://github.com/boldsoftware/sketch/issues/6\n\n- Changed resize property from \u0027none\u0027 to \u0027vertical\u0027 to allow user resizing\n- Increased max-height from 120px to 300px to allow more expansion\n- Enhanced user experience by allowing them to resize the chat input according to their needs\n- Automatically resize the textarea as the user types (up to max-height)\n\nCo-Authored-By: sketch\n"
    },
    {
      "commit": "b29f8911e4c0d99d6c32866d7174a51b6730e9d8",
      "tree": "34e445527e949fb27970d4264db8a776323be485",
      "parents": [
        "ec3ad1a7798b0dc1d17d363c91680b7828d7fce2"
      ],
      "author": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Sun Apr 20 15:39:11 2025 -0700"
      },
      "committer": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Sun Apr 20 15:53:30 2025 -0700"
      },
      "message": "webui: Migrate from @open-wc/testing to Playwright\n"
    },
    {
      "commit": "71941bdfa1156b748072e2dfe61c714d3ed02913",
      "tree": "28eeb5cb68bef3e0eb5b6a5ec63d17f4150e4fbb",
      "parents": [
        "9abbf92a1c58300005971d7f89b301620d59e883"
      ],
      "author": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Fri Apr 18 13:31:48 2025 -0700"
      },
      "committer": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Fri Apr 18 14:01:53 2025 -0700"
      },
      "message": "loop/webui: add prettier\n"
    },
    {
      "commit": "86b56862f8d3e192646a17548ef5294582c31f8f",
      "tree": "d0235f3f56695de8e6281ba3f57a663847204f33",
      "parents": [
        "f5bb3d3f1aa33e2a066c4139675f096f73c1f9d4"
      ],
      "author": {
        "name": "Sean McCullough",
        "email": "banksean@gmail.com",
        "time": "Fri Apr 18 13:04:03 2025 -0700"
      },
      "committer": {
        "name": "GitHub",
        "email": "noreply@github.com",
        "time": "Fri Apr 18 13:04:03 2025 -0700"
      },
      "message": "loop/webui: swtich to web components impl (#1)\n\n* loop/webui: swtich to web components impl\n\nThis change reorganizes the original vibe-coded\nfrontend code into a structure that\u0027s much\neasier for a human to read and reason about,\nwhile retaining the user-visible functionality\nof its vibe-coded predecessor. Perhaps most\nimportantly, this change makes the code testable.\n\nSome other notable details:\n\nThis does not use any of the popular large web\nframeworks, but instead follows more of an\n\"a la carte\" approach: leverage features\nthat already exist in modern web browsers,\nlike custom elements and shadow DOM.\n\nTemplating and basic component lifecycle\nmanagement are provided by lit.\n\nState management is nothing fancy. It\ndoesn\u0027t use any library or framework, just\na basic \"Events up, properties down\"\napproach.\n\n* fix bad esbuild.go merge\n\n* loop/webui: don\u0027t bundle src/web-components/demo\n\n* loop/webui: don\u0027t \u0027npm ci\u0027 dev deps in the container\n\n* rebase to main, undo README.md changes, add webuil.Build() call to LaunchContainer()"
    }
  ]
}
