{"id":10065,"date":"2025-10-19T01:07:51","date_gmt":"2025-10-19T01:07:51","guid":{"rendered":"https:\/\/pokecon.jp\/job\/?p=10065"},"modified":"2025-10-19T01:07:51","modified_gmt":"2025-10-19T01:07:51","slug":"figma%e3%81%8b%e3%82%89flutter%e3%81%b8-%e2%94%80%e2%94%80-%e3%83%87%e3%82%b6%e3%82%a4%e3%83%b3%e3%83%88%e3%83%bc%e3%82%af%e3%83%b3%e8%87%aa%e5%8b%95%e5%a4%89%e6%8f%9b%e3%81%a8ui%e3%82%ab%e3%82%bf","status":"publish","type":"post","link":"https:\/\/pokecon.jp\/job\/10065\/","title":{"rendered":"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f &#8211; ZOZO TECH BLOG"},"content":{"rendered":"\n<\/p>\n<div>\n<p><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20251016\/20251016120140.png\" alt=\"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f\"\/><\/p>\n<h2 id=\"\u306f\u3058\u3081\u306b\">\u306f\u3058\u3081\u306b<\/h2>\n<p>\u3053\u3093\u306b\u3061\u306f\u3001\u65b0\u898f\u4e8b\u696d\u90e8\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30d6\u30ed\u30c3\u30af\u306e\u5b89\u571f\u7422\u6717\u3067\u3059\u3002\u666e\u6bb5\u306fZOZO\u30de\u30c3\u30c1\u306eFlutter\u30a2\u30d7\u30ea\u958b\u767a\u3092\u62c5\u5f53\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>ZOZO\u30de\u30c3\u30c1\u306f2025\u5e746\u6708\u306b\u30ea\u30ea\u30fc\u30b9\u3055\u308c\u305f\u3001\u30bc\u30ed\u304b\u3089\u7acb\u3061\u4e0a\u3052\u305f\u30de\u30c3\u30c1\u30f3\u30b0\u30a2\u30d7\u30ea\u3067\u3059\u3002<iframe src=\"https:\/\/hatenablog-parts.com\/embed?url=https%3A%2F%2Fzozomatch.jp%2F\" title=\"ZOZO\u30de\u30c3\u30c1(\u30be\u30be\u30de\u30c3\u30c1) | \u604b\u6d3b\u30de\u30c3\u30c1\u30f3\u30b0\u30a2\u30d7\u30ea\" class=\"embed-card embed-webcard\" scrolling=\"no\" frameborder=\"0\" style=\"display: block; width: 100%; height: 155px; max-width: 500px; margin: 10px 0px;\" loading=\"lazy\"><\/iframe><cite class=\"hatena-citation\"><a target=\"_blank\" href=\"https:\/\/zozomatch.jp\/\">zozomatch.jp<\/a><\/cite>\u672c\u8a18\u4e8b\u3067\u306f\u3001\u958b\u767a\u521d\u671f\u304b\u3089\u53d6\u308a\u7d44\u3093\u3067\u304d\u305f\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u306e\u5c0e\u5165\u306b\u3088\u3063\u3066\u3001\u3069\u306e\u3088\u3046\u306b\u958b\u767a\u52b9\u7387\u3068UI\u306e\u54c1\u8cea\u3092\u5411\u4e0a\u3055\u305b\u305f\u304b\u3001\u305d\u3057\u3066\u305d\u308c\u3092\u652f\u3048\u308b\u5177\u4f53\u7684\u306a\u904b\u7528\u30d7\u30ed\u30bb\u30b9\u3084\u4ed5\u7d44\u307f\u306b\u3064\u3044\u3066\u3054\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n<p>\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u7d99\u7d9a\u7684\u306b\u6210\u9577\u3055\u305b\u308b\u3046\u3048\u3067\u3001\u30c7\u30b6\u30a4\u30f3\u3068\u5b9f\u88c5\u306e\u30ba\u30ec\u3092\u6700\u5c0f\u5316\u3057\u3001\u8ab0\u304c\u958b\u767a\u3057\u3066\u3082\u4e00\u5b9a\u306e\u54c1\u8cea\u304c\u4fdd\u305f\u308c\u308b\u72b6\u614b\u3092\u3069\u3046\u5b9f\u73fe\u3059\u308b\u304b\u306f\u91cd\u8981\u306a\u30c6\u30fc\u30de\u3067\u3059\u3002\u305d\u306e\u8ab2\u984c\u306b\u5bfe\u3057\u3001\u79c1\u305f\u3061\u306f\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u30fbUI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u30fbUI\u30ab\u30bf\u30ed\u30b0\u3092\u8ef8\u306b\u3057\u305f\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3057\u307e\u3057\u305f\u3002<\/p>\n<h2 id=\"\u76ee\u6b21\">\u76ee\u6b21<\/h2>\n<h2 id=\"\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u69cb\u7bc9\u306e\u80cc\u666f\u3068\u8ab2\u984c\">\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u69cb\u7bc9\u306e\u80cc\u666f\u3068\u8ab2\u984c<\/h2>\n<h3 id=\"\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u3068\u306f\">\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u3068\u306f<\/h3>\n<p>\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u3068\u306f\u3001\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\uff08\u8272\u3001\u6587\u5b57\u30b5\u30a4\u30ba\u3001\u4f59\u767d\u306a\u3069\uff09\u3001UI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3001\u30ac\u30a4\u30c9\u30e9\u30a4\u30f3\u3001\u5b9f\u88c5\u30b3\u30fc\u30c9\u3092\u7d71\u5408\u7684\u306b\u7ba1\u7406\u3059\u308b\u4ed5\u7d44\u307f\u3067\u3059\u3002\u5358\u306a\u308b\u30b9\u30bf\u30a4\u30eb\u30ac\u30a4\u30c9\u3084\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u306f\u306a\u304f\u3001\u30c7\u30b6\u30a4\u30f3\u3068\u5b9f\u88c5\u306e\u4e00\u8cab\u6027\u3092\u4fdd\u3061\u306a\u304c\u3089\u3001\u30c1\u30fc\u30e0\u5168\u4f53\u304c\u52b9\u7387\u7684\u306b\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u958b\u767a\u30fb\u904b\u7528\u3059\u308b\u305f\u3081\u306e\u5171\u901a\u57fa\u76e4\u3068\u306a\u308a\u307e\u3059\u3002<\/p>\n<h3 id=\"\u306a\u305c\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u304c\u5fc5\u8981\u3060\u3063\u305f\u306e\u304b\">\u306a\u305c\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u304c\u5fc5\u8981\u3060\u3063\u305f\u306e\u304b<\/h3>\n<p>ZOZO\u30de\u30c3\u30c1\u306f\u3001\u65e2\u5b58\u30b5\u30fc\u30d3\u30b9\u306e\u6539\u4fee\u3067\u306f\u306a\u304f\u3001\u30bc\u30ed\u304b\u3089\u7acb\u3061\u4e0a\u3052\u305f\u65b0\u898f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u3059\u3002\u307e\u305f\u3001ZOZO\u306b\u3068\u3063\u3066\u672c\u683c\u7684\u306aFlutter\u30a2\u30d7\u30ea\u958b\u767a\u3068\u306a\u308b\u305f\u3081\u3001\u30ce\u30a6\u30cf\u30a6\u84c4\u7a4d\u3082\u91cd\u8981\u306a\u76ee\u7684\u306e1\u3064\u3067\u3057\u305f\u3002<\/p>\n<p>\u65b0\u898f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306f\u3001\u30ec\u30ac\u30b7\u30fc\u30b3\u30fc\u30c9\u306b\u7e1b\u3089\u308c\u305a\u3001\u6700\u521d\u304b\u3089\u4e00\u8cab\u3057\u305f\u8a2d\u8a08\u57fa\u76e4\u3092\u69cb\u7bc9\u3067\u304d\u308b\u8cb4\u91cd\u306a\u6a5f\u4f1a\u3067\u3059\u3002\u3053\u306e\u6a5f\u4f1a\u3092\u6d3b\u304b\u3057\u3001\u5c06\u6765\u3082\u30b9\u30e0\u30fc\u30ba\u306b\u958b\u767a\u3092\u7d9a\u3051\u3089\u308c\u308b\u4ed5\u7d44\u307f\u3068\u3057\u3066\u3001\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u306e\u5c0e\u5165\u3092\u6c7a\u3081\u307e\u3057\u305f\u3002\u30c7\u30b6\u30a4\u30f3\u3068\u5b9f\u88c5\u306e\u30ba\u30ec\u3092\u6700\u5c0f\u5316\u3057\u3001\u518d\u5229\u7528\u3057\u3084\u3059\u3044\u57fa\u76e4\u3065\u304f\u308a\u306b\u6ce8\u529b\u3059\u308b\u3053\u3068\u3067\u3001\u77ed\u671f\u7684\u306a\u958b\u767a\u52b9\u7387\u3060\u3051\u3067\u306a\u304f\u3001\u9577\u671f\u7684\u306a\u4fdd\u5b88\u6027\u3082\u78ba\u4fdd\u3067\u304d\u308b\u3068\u8003\u3048\u305f\u304b\u3089\u3067\u3059\u3002<\/p>\n<h4 id=\"\u76f4\u9762\u3057\u3066\u3044\u305f\u8ab2\u984c\">\u76f4\u9762\u3057\u3066\u3044\u305f\u8ab2\u984c<\/h4>\n<h5 id=\"1-\u30c7\u30b6\u30a4\u30f3\u306e\u4e00\u8cab\u6027\u304c\u4fdd\u3066\u306a\u3044\">1. \u30c7\u30b6\u30a4\u30f3\u306e\u4e00\u8cab\u6027\u304c\u4fdd\u3066\u306a\u3044<\/h5>\n<ul>\n<li>\u540c\u3058\u300c\u30dc\u30bf\u30f3\u300d\u3067\u3082\u753b\u9762\u3054\u3068\u306b\u89d2\u4e38\u3084\u4f59\u767d\u304c\u9055\u3046<\/li>\n<li>\u30c6\u30ad\u30b9\u30c8\u30ab\u30e9\u30fc\u304c <code>#2D2D2D<\/code>\u3001<code>#333333<\/code>\u3001<code>rgba(45,45,45,1)<\/code> \u306a\u3069\u8907\u6570\u5b58\u5728<\/li>\n<li>\u5b9f\u88c5\u306b\u5dee\u5206\u304c\u751f\u307e\u308c\u3084\u3059\u304f\u3001\u7d50\u679c\u3068\u3057\u3066UI\u306e\u30d0\u30e9\u3064\u304d\u304c\u767a\u751f<\/li>\n<\/ul>\n<h5 id=\"2-\u30c7\u30b6\u30a4\u30f3\u5909\u66f4\u306b\u304b\u304b\u308b\u30b3\u30b9\u30c8\u304c\u9ad8\u3044\">2. \u30c7\u30b6\u30a4\u30f3\u5909\u66f4\u306b\u304b\u304b\u308b\u30b3\u30b9\u30c8\u304c\u9ad8\u3044<\/h5>\n<ul>\n<li>\u30d6\u30e9\u30f3\u30c9\u30ab\u30e9\u30fc\u306e\u5909\u66f4\u306b\u4f55\u5341\u30fb\u4f55\u767e\u7b87\u6240\u306e\u4fee\u6b63\u304c\u5fc5\u8981<\/li>\n<li>\u4e00\u90e8\u3060\u3051\u53cd\u6620\u3057\u3066\u4e0d\u6574\u5408\u304c\u767a\u751f<\/li>\n<li>\u5c0f\u3055\u306a\u5909\u66f4\u3067\u3082\u300c\u3069\u3053\u3092\u76f4\u3059\u304b\u300d\u304c\u5c5e\u4eba\u7684<\/li>\n<\/ul>\n<h5 id=\"3-\u30c1\u30fc\u30e0\u5185\u306e\u8a8d\u8b58\u306e\u30ba\u30ec\">3. \u30c1\u30fc\u30e0\u5185\u306e\u8a8d\u8b58\u306e\u30ba\u30ec<\/h5>\n<ul>\n<li>\u30c7\u30b6\u30a4\u30ca\u30fc\u3068\u30a8\u30f3\u30b8\u30cb\u30a2\u306e\u9593\u3067\u300c\u3069\u308c\u304c\u6b63\u3057\u3044\u4ed5\u69d8\u304b\u300d\u304c\u66d6\u6627<\/li>\n<li>\u300c\u4f3c\u305f\u3088\u3046\u306a\u753b\u9762\u3092\u53c2\u8003\u306b\u3057\u305f\u3089\u3001\u5b9f\u306f\u5225\u4ed5\u69d8\u3060\u3063\u305f\u300d<\/li>\n<li>\u5b9f\u88c5\u3068Figma\u306e\u9055\u3044\u306b\u3064\u3044\u3066\u4f55\u5ea6\u3082\u78ba\u8a8d\u304c\u5fc5\u8981<\/li>\n<\/ul>\n<p>\u3053\u308c\u3089\u306e\u8ab2\u984c\u306f\u3001\u5358\u306a\u308b\u52b9\u7387\u306e\u554f\u984c\u3067\u306f\u306a\u304f\u3001\u30d7\u30ed\u30c0\u30af\u30c8\u306e\u54c1\u8cea\u3068\u30c1\u30fc\u30e0\u306e\u30e2\u30c1\u30d9\u30fc\u30b7\u30e7\u30f3\u306b\u76f4\u7d50\u3059\u308b\u91cd\u8981\u306a\u554f\u984c\u3067\u3057\u305f\u3002<\/p>\n<h2 id=\"\u89e3\u6c7a\u7b56\u306e\u5168\u4f53\u50cf\">\u89e3\u6c7a\u7b56\u306e\u5168\u4f53\u50cf<\/h2>\n<p>\u3053\u308c\u3089\u306e\u8ab2\u984c\u3092\u89e3\u6c7a\u3059\u308b\u305f\u3081\u3001\u79c1\u305f\u3061\u306f3\u3064\u306e\u4ed5\u7d44\u307f\u3092\u7d44\u307f\u5408\u308f\u305b\u305f\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3057\u307e\u3057\u305f\u3002<\/p>\n<p>1\u3064\u76ee\u306f\u3001\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u306e\u81ea\u52d5\u5909\u63db\u3067\u3059\u3002Figma\u3067\u5b9a\u7fa9\u3057\u305f\u8272\u3001\u6587\u5b57\u30b5\u30a4\u30ba\u3001\u4f59\u767d\u306a\u3069\u306e\u30c7\u30b6\u30a4\u30f3\u8981\u7d20\u3092\u3001<a target=\"_blank\" href=\"https:\/\/github.com\/style-dictionary\/style-dictionary\">Style Dictionary<\/a>\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u4f7f\u3063\u3066Dart\u30b3\u30fc\u30c9\u306b\u81ea\u52d5\u5909\u63db\u3059\u308b\u4ed5\u7d44\u307f\u3092\u4f5c\u308a\u307e\u3057\u305f\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u30c7\u30b6\u30a4\u30ca\u30fc\u304cFigma\u3067\u5024\u3092\u66f4\u65b0\u3059\u308c\u3070\u3001\u30a8\u30f3\u30b8\u30cb\u30a2\u306f\u81ea\u52d5\u751f\u6210\u3055\u308c\u305f\u30b3\u30fc\u30c9\u3092\u4f7f\u3046\u3060\u3051\u3067\u3001\u5e38\u306b\u6700\u65b0\u306e\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<p>2\u3064\u76ee\u306f\u3001\u518d\u5229\u7528\u53ef\u80fd\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u6574\u5099\u3067\u3059\u3002\u30dc\u30bf\u30f3\u3001\u30ab\u30fc\u30c9\u3001\u30d5\u30a9\u30fc\u30e0\u306a\u3069\u3001\u30a2\u30d7\u30ea\u5168\u4f53\u3067\u4f7f\u7528\u3059\u308b50\u4ee5\u4e0a\u306eUI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u7d71\u4e00\u7684\u306b\u5b9f\u88c5\u3057\u307e\u3057\u305f\u3002\u5404\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306f\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u3092\u4f7f\u7528\u3057\u3066\u3044\u308b\u305f\u3081\u3001\u4e00\u8cab\u6027\u306e\u3042\u308bUI\u3092\u7c21\u5358\u306b\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>3\u3064\u76ee\u306f\u3001Widgetbook\u306b\u3088\u308b\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u30ab\u30bf\u30ed\u30b0\u306e\u69cb\u7bc9\u3067\u3059\u3002\u3059\u3079\u3066\u306eUI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u78ba\u8a8d\u3067\u304d\u308b\u30ab\u30bf\u30ed\u30b0\u74b0\u5883\u3092\u6574\u5099\u3057\u307e\u3057\u305f\u3002\u5b9f\u88c5\u8005\u306f\u3001\u30c7\u30b6\u30a4\u30f3\u306e\u78ba\u8a8d\u3084\u72b6\u614b\u306e\u30d0\u30ea\u30a8\u30fc\u30b7\u30e7\u30f3\u3092\u78ba\u8a8d\u3057\u305f\u3044\u3068\u304d\u306b\u3001\u3053\u306e\u30ab\u30bf\u30ed\u30b0\u3092\u6d3b\u7528\u3057\u3066\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u898b\u305f\u76ee\u3092\u7d20\u65e9\u304f\u628a\u63e1\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u3053\u306e3\u3064\u306e\u4ed5\u7d44\u307f\u304c\u76f8\u4e92\u306b\u9023\u643a\u3059\u308b\u3053\u3068\u3067\u3001\u30c7\u30b6\u30a4\u30f3\u3068\u5b9f\u88c5\u306e\u30ae\u30e3\u30c3\u30d7\u3092\u89e3\u6d88\u3057\u3001UI\u306e\u4e00\u8cab\u6027\u3084\u958b\u767a\u30b9\u30d4\u30fc\u30c9\u306e\u5411\u4e0a\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u518d\u5229\u7528\u306e\u4fc3\u9032\u3068\u3044\u3063\u305f\u9762\u3067\u3001\u30c1\u30fc\u30e0\u5168\u4f53\u306e\u751f\u7523\u6027\u3092\u7740\u5b9f\u306b\u9ad8\u3081\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3057\u305f\u3002<\/p>\n<h2 id=\"\u5177\u4f53\u7684\u306a\u5b9f\u88c5\u3068\u904b\u7528\">\u5177\u4f53\u7684\u306a\u5b9f\u88c5\u3068\u904b\u7528<\/h2>\n<p>\u3053\u3053\u304b\u3089\u306f\u3001\u3053\u308c\u3089\u306e\u4ed5\u7d44\u307f\u3092\u3069\u306e\u3088\u3046\u306b\u5b9f\u88c5\u3057\u3001\u65e5\u3005\u306e\u958b\u767a\u3067\u904b\u7528\u3057\u3066\u3044\u308b\u304b\u3092\u5177\u4f53\u7684\u306b\u7d39\u4ecb\u3057\u3066\u3044\u304d\u307e\u3059\u3002\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u306e\u81ea\u52d5\u5909\u63db\u30d7\u30ed\u30bb\u30b9\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u958b\u767a\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3001\u305d\u3057\u3066Widgetbook\u3092\u4f7f\u3063\u305f\u54c1\u8cea\u7ba1\u7406\u306e\u5b9f\u8df5\u306b\u3064\u3044\u3066\u3001\u5b9f\u969b\u306e\u30b3\u30fc\u30c9\u3084\u8a2d\u5b9a\u4f8b\u3092\u4ea4\u3048\u306a\u304c\u3089\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n<h2 id=\"1-\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u306e\u81ea\u52d5\u5909\u63db\">1. \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u306e\u81ea\u52d5\u5909\u63db<\/h2>\n<p>ZOZO\u30de\u30c3\u30c1\u3067\u306f\u3001Figma\u3067\u7ba1\u7406\u3057\u3066\u3044\u308b\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\uff08\u8272\u3001\u30bf\u30a4\u30dd\u30b0\u30e9\u30d5\u30a3\u3001\u4f59\u767d\u3001\u89d2\u4e38\u306a\u3069\uff09\u3092Dart\u30b3\u30fc\u30c9\u306b\u81ea\u52d5\u5909\u63db\u3059\u308b\u4ed5\u7d44\u307f\u3092\u69cb\u7bc9\u3057\u307e\u3057\u305f\u3002<\/p>\n<h3 id=\"\u5b9a\u7fa9\u3057\u3066\u3044\u308b\u30c8\u30fc\u30af\u30f3\u306e\u7a2e\u985e\">\u5b9a\u7fa9\u3057\u3066\u3044\u308b\u30c8\u30fc\u30af\u30f3\u306e\u7a2e\u985e<\/h3>\n<h4 id=\"Color\u8272\">Color\uff08\u8272\uff09<\/h4>\n<p><figure class=\"figure-image figure-image-fotolife\" title=\"\"><span itemscope=\"\" itemtype=\"http:\/\/schema.org\/Photograph\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20250930\/20250930163537.png\" width=\"552\" height=\"1200\" loading=\"lazy\" title=\"\" class=\"hatena-fotolife\" itemprop=\"image\"\/><\/span><figcaption>Color\u30c8\u30fc\u30af\u30f3\u306e\u30ae\u30e3\u30e9\u30ea\u30fc\u8868\u793a\u3002<br \/>\u30d6\u30e9\u30f3\u30c9\u30ab\u30e9\u30fc\u3001\u30c6\u30ad\u30b9\u30c8\u8272\u3001\u80cc\u666f\u8272\u306a\u3069\u3001\u30a2\u30d7\u30ea\u5168\u4f53\u3067\u4f7f\u7528\u3059\u308b\u8272\u5f69\u3002<\/figcaption><\/figure>\n<\/p>\n<h4 id=\"Typography\u6587\u5b57\u30b9\u30bf\u30a4\u30eb\">Typography\uff08\u6587\u5b57\u30b9\u30bf\u30a4\u30eb\uff09<\/h4>\n<p><figure class=\"figure-image figure-image-fotolife\" title=\"\"><span itemscope=\"\" itemtype=\"http:\/\/schema.org\/Photograph\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20250930\/20250930163544.png\" width=\"555\" height=\"1200\" loading=\"lazy\" title=\"\" class=\"hatena-fotolife\" itemprop=\"image\"\/><\/span><figcaption>Typography\u30c8\u30fc\u30af\u30f3\u306e\u5b9a\u7fa9\u4e00\u89a7\u3002<br \/>\u30d5\u30a9\u30f3\u30c8\u30b5\u30a4\u30ba\u3001\u30a6\u30a7\u30a4\u30c8\u3001\u884c\u9593\u306a\u3069\u306e\u6587\u5b57\u306b\u95a2\u3059\u308b\u5c5e\u6027\u3002<\/figcaption><\/figure>\n<\/p>\n<h4 id=\"Spacing\u4f59\u767d\">Spacing\uff08\u4f59\u767d\uff09<\/h4>\n<p><figure class=\"figure-image figure-image-fotolife\" title=\"\"><span itemscope=\"\" itemtype=\"http:\/\/schema.org\/Photograph\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20250930\/20250930163552.png\" width=\"553\" height=\"1200\" loading=\"lazy\" title=\"\" class=\"hatena-fotolife\" itemprop=\"image\"\/><\/span><figcaption>Spacing\u30c8\u30fc\u30af\u30f3\u306e\u30b5\u30a4\u30ba\u4e00\u89a7\u3002<br \/>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u9593\u306e\u4f59\u767d\u3084\u30d1\u30c7\u30a3\u30f3\u30b0\u306e\u5024\u3002<\/figcaption><\/figure>\n<\/p>\n<h4 id=\"Radius\u89d2\u4e38\">Radius\uff08\u89d2\u4e38\uff09<\/h4>\n<p><figure class=\"figure-image figure-image-fotolife\" title=\"\"><span itemscope=\"\" itemtype=\"http:\/\/schema.org\/Photograph\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20250930\/20250930163559.png\" width=\"547\" height=\"1200\" loading=\"lazy\" title=\"\" class=\"hatena-fotolife\" itemprop=\"image\"\/><\/span><figcaption>Radius\u30c8\u30fc\u30af\u30f3\u306e\u89d2\u4e38\u30b5\u30a4\u30ba\u4e00\u89a7\u3002<br \/>\u30dc\u30bf\u30f3\u3084\u30ab\u30fc\u30c9\u306a\u3069\u306e\u89d2\u4e38\u306e\u534a\u5f84\u3002<\/figcaption><\/figure>\n<\/p>\n<h4 id=\"Shadow\u5f71\">Shadow\uff08\u5f71\uff09<\/h4>\n<p><figure class=\"figure-image figure-image-fotolife\" title=\"\"><span itemscope=\"\" itemtype=\"http:\/\/schema.org\/Photograph\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20250930\/20250930121021.png\" width=\"668\" height=\"1200\" loading=\"lazy\" title=\"\" class=\"hatena-fotolife\" itemprop=\"image\"\/><\/span><figcaption>Shadow\u30c8\u30fc\u30af\u30f3\u306e\u5f71\u306e\u5b9a\u7fa9\u4e00\u89a7\u3002<br \/>\u30ab\u30fc\u30c9\u3084\u30e2\u30fc\u30c0\u30eb\u306a\u3069\u306b\u9069\u7528\u3059\u308b\u5f71\u306e\u5b9a\u7fa9\u3002<\/figcaption><\/figure>\n<\/p>\n<p>\u968e\u5c64\u7684\u306a\u547d\u540d\u898f\u5247\u306b\u3088\u308a\u3001<code>ZNMColors.textPrimary<\/code>\u3084<code>ZNMUnit.unit16px<\/code>\u3068\u3044\u3063\u305f\u76f4\u611f\u7684\u306a\u540d\u524d\u3067\u30c8\u30fc\u30af\u30f3\u3092\u53c2\u7167\u3067\u304d\u307e\u3059\u3002<\/p>\n<h3 id=\"\u5909\u63db\u30d7\u30ed\u30bb\u30b9\u306e\u4ed5\u7d44\u307f\">\u5909\u63db\u30d7\u30ed\u30bb\u30b9\u306e\u4ed5\u7d44\u307f<\/h3>\n<h4 id=\"\u306a\u305cStyle-Dictionary\u3092\u63a1\u7528\u3057\u305f\u306e\u304b\">\u306a\u305cStyle Dictionary\u3092\u63a1\u7528\u3057\u305f\u306e\u304b<\/h4>\n<p>\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u306e\u904b\u7528\u3067\u6700\u3082\u91cd\u8981\u306a\u306e\u306f\u300c\u5909\u66f4\u3078\u306e\u5bfe\u5fdc\u529b\u300d\u3067\u3059\u3002\u79c1\u305f\u3061\u306f\u4ee5\u4e0b\u306e\u8ab2\u984c\u3092\u89e3\u6c7a\u3057\u305f\u3044\u3068\u8003\u3048\u3066\u3044\u307e\u3057\u305f\u3002<\/p>\n<ol>\n<li>\n<p><strong>\u30c7\u30b6\u30a4\u30f3\u5909\u66f4\u306e\u5373\u5ea7\u306e\u53cd\u6620<\/strong><\/p>\n<ul>\n<li>Figma\u3067\u30ab\u30e9\u30fc\u3092\u5909\u66f4\u3057\u305f\u3089\u3001\u30b3\u30de\u30f3\u30c91\u3064\u3067\u5168\u753b\u9762\u306b\u53cd\u6620\u3057\u305f\u3044<\/li>\n<li>\u624b\u52d5\u3067\u4f55\u5341\u7b87\u6240\u3082\u4fee\u6b63\u3059\u308b\u306e\u306f\u975e\u52b9\u7387\u3067\u30df\u30b9\u306e\u6e29\u5e8a<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u56fa\u6709\u306e\u8abf\u6574<\/strong><\/p>\n<ul>\n<li>Figma\u306e\u30d5\u30a9\u30f3\u30c8\u30a6\u30a7\u30a4\u30c8\u3068Flutter\u306e\u898b\u305f\u76ee\u304c\u7570\u306a\u308b\u554f\u984c<\/li>\n<li>\u65e5\u672c\u8a9e\u30d5\u30a9\u30f3\u30c8\u306e\u6271\u3044\u306a\u3069\u3001\u5b9f\u88c5\u7279\u6709\u306e\u8abf\u6574\u304c\u5fc5\u8981<\/li>\n<li>\u5c06\u6765\u7684\u306bAndroid\/iOS\u3067\u7570\u306a\u308b\u8abf\u6574\u304c\u5fc5\u8981\u306b\u306a\u308b\u53ef\u80fd\u6027<\/li>\n<\/ul>\n<\/li>\n<li>\n<p><strong>\u4e00\u8cab\u6027\u306e\u62c5\u4fdd<\/strong><\/p>\n<ul>\n<li>\u30c7\u30b6\u30a4\u30ca\u30fc\u304c\u5b9a\u7fa9\u3057\u305f\u5024\u3092\u3001\u30a8\u30f3\u30b8\u30cb\u30a2\u304c\u52dd\u624b\u306b\u5909\u66f4\u3067\u304d\u306a\u3044\u4ed5\u7d44\u307f<\/li>\n<li>\u300c\u6b63\u300d\u306fFigma\u306b\u3042\u308a\u3001\u5b9f\u88c5\u306f\u5e38\u306b\u305d\u3053\u304b\u3089\u81ea\u52d5\u751f\u6210\u3055\u308c\u308b\u72b6\u614b<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p><a target=\"_blank\" href=\"https:\/\/styledictionary.com\/\">Style Dictionary<\/a>\u3092\u9078\u3093\u3060\u7406\u7531\u306f\u3001\u3053\u308c\u3089\u306e\u8981\u4ef6\u3092\u6e80\u305f\u3059\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6027\u306e\u9ad8\u3055\u306b\u3042\u308a\u307e\u3059\u3002Style Dictionary\u306f\u3001Amazon\u304c\u958b\u767a\u3057\u305f\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u5909\u63db\u30c4\u30fc\u30eb\u3067\u3001JSON\u5f62\u5f0f\u306e\u30c8\u30fc\u30af\u30f3\u3092\u69d8\u3005\u306a\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\uff08iOS\u3001Android\u3001Web\u7b49\uff09\u306e\u30b3\u30fc\u30c9\u306b\u5909\u63db\u3067\u304d\u307e\u3059\u3002\u5358\u306a\u308b\u5024\u306e\u5909\u63db\u3060\u3051\u3067\u306a\u304f\u3001TypeScript\u3067\u72ec\u81ea\u306e\u5909\u63db\u30ed\u30b8\u30c3\u30af\u3092\u5b9f\u88c5\u3067\u304d\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u56fa\u6709\u306e\u8981\u4ef6\u306b\u67d4\u8edf\u306b\u5bfe\u5fdc\u3067\u304d\u307e\u3057\u305f\u3002<\/p>\n<h4 id=\"\u6280\u8853\u30b9\u30bf\u30c3\u30af\">\u6280\u8853\u30b9\u30bf\u30c3\u30af<\/h4>\n<ul>\n<li><a target=\"_blank\" href=\"https:\/\/styledictionary.com\/\">Style Dictionary v5<\/a> &#8211; \u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u53ef\u80fd\u306a\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u5909\u63db\u30c4\u30fc\u30eb<\/li>\n<li>TypeScript &#8211; \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u56fa\u6709\u306e\u5909\u63db\u30ed\u30b8\u30c3\u30af\u3092\u5b9f\u88c5<\/li>\n<li><a target=\"_blank\" href=\"https:\/\/www.figma.com\/community\/plugin\/888356646278934516\/design-tokens\">Design Tokens Plugin<\/a> &#8211; Figma\u304b\u3089\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u3092\u30a8\u30af\u30b9\u30dd\u30fc\u30c8<\/li>\n<\/ul>\n<h4 id=\"\u81ea\u52d5\u5316\u306e\u30d5\u30ed\u30fc\">\u81ea\u52d5\u5316\u306e\u30d5\u30ed\u30fc<\/h4>\n<ol>\n<li>\n<p>Figma\u3067\u30c8\u30fc\u30af\u30f3\u3092\u5b9a\u7fa9<\/p>\n<ul>\n<li>\u30c7\u30b6\u30a4\u30ca\u30fc\u304c\u30ab\u30e9\u30fc\u30d1\u30ec\u30c3\u30c8\u3001\u30bf\u30a4\u30dd\u30b0\u30e9\u30d5\u30a3\u306a\u3069\u3092\u8a2d\u5b9a<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>JSON\u3068\u3057\u3066\u30a8\u30af\u30b9\u30dd\u30fc\u30c8<\/p>\n<\/li>\n<li>\n<p>Style Dictionary\u3067\u5909\u63db<\/p>\n<ul>\n<li>TypeScript\u3067\u30ab\u30b9\u30bf\u30e0\u5909\u63db\u30ed\u30b8\u30c3\u30af\u3092\u5b9f\u88c5<\/li>\n<li>\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u56fa\u6709\u306e\u8abf\u6574\uff08\u30d5\u30a9\u30f3\u30c8\u30a6\u30a7\u30a4\u30c8\u3001\u65e5\u672c\u8a9e\u30d5\u30a9\u30f3\u30c8\u306a\u3069\uff09\u3092\u9069\u7528<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>Dart\u30b3\u30fc\u30c9\u3092\u81ea\u52d5\u751f\u6210<\/p>\n<ul>\n<li><code>config.json<\/code>\u3067\u51fa\u529b\u5148\u3068\u30d5\u30a3\u30eb\u30bf\u30ea\u30f3\u30b0\u3092\u8a2d\u5b9a<\/li>\n<li><code>ZNMColors<\/code>\u3001<code>ZNMTypography<\/code>\u3001<code>ZNMUnit<\/code>\u306a\u3069\u306e\u30af\u30e9\u30b9\u3068\u3057\u3066\u751f\u6210<\/li>\n<li>\u578b\u5b89\u5168\u3067\u3001IDE\u306e\u88dc\u5b8c\u304c\u52b9\u304f\u30c8\u30fc\u30af\u30f3\u30af\u30e9\u30b9\u3068\u3057\u3066\u51fa\u529b<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h4 id=\"\u904b\u7528\u30d5\u30ed\u30fc\">\u904b\u7528\u30d5\u30ed\u30fc<\/h4>\n<pre class=\"code lang-sh\" data-lang=\"sh\" data-unlink=\"\">\n<span class=\"synStatement\">cd<\/span> tools\/design-token-to-dart\nnpm run build  \n<\/pre>\n<p>\u305f\u3063\u305f1\u30b3\u30de\u30f3\u30c9\u3067\u3001Figma\u306e\u6700\u65b0\u30c7\u30b6\u30a4\u30f3\u304c\u30a2\u30d7\u30ea\u5168\u4f53\u306b\u53cd\u6620\u3055\u308c\u307e\u3059\u3002\u30d6\u30e9\u30f3\u30c9\u30ab\u30e9\u30fc\u306e\u5909\u66f4\u3082\u3001\u4f59\u767d\u306e\u8abf\u6574\u3082\u3001\u3059\u3079\u3066\u81ea\u52d5\u5316\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<h4 id=\"\u5b9f\u969b\u306e\u5909\u63db\u4f8b\">\u5b9f\u969b\u306e\u5909\u63db\u4f8b<\/h4>\n<pre class=\"code lang-json\" data-lang=\"json\" data-unlink=\"\"><span class=\"synError\">\/\/ tokens\/design-tokens.tokens.json\uff08Figma\u304b\u3089\u30a8\u30af\u30b9\u30dd\u30fc\u30c8\uff09<\/span>\n<span class=\"synSpecial\">{<\/span>\n  \"<span class=\"synStatement\">color styles<\/span>\": <span class=\"synSpecial\">{<\/span>\n    \"<span class=\"synStatement\">text<\/span>\": <span class=\"synSpecial\">{<\/span>\n      \"<span class=\"synStatement\">primary<\/span>\": <span class=\"synSpecial\">{<\/span> \"<span class=\"synStatement\">value<\/span>\": \"<span class=\"synConstant\">#2D2D2D<\/span>\" <span class=\"synSpecial\">}<\/span>\n    <span class=\"synSpecial\">}<\/span>\n  <span class=\"synSpecial\">}<\/span>,\n  \"<span class=\"synStatement\">typography<\/span>\": <span class=\"synSpecial\">{<\/span>\n    \"<span class=\"synStatement\">jp<\/span>\": <span class=\"synSpecial\">{<\/span>\n      \"<span class=\"synStatement\">bodyM<\/span>\": <span class=\"synSpecial\">{<\/span>\n        \"<span class=\"synStatement\">fontSize<\/span>\": <span class=\"synConstant\">14<\/span>,\n        \"<span class=\"synStatement\">fontWeight<\/span>\": <span class=\"synConstant\">400<\/span>,\n        \"<span class=\"synStatement\">lineHeight<\/span>\": <span class=\"synConstant\">21<\/span>\n      <span class=\"synSpecial\">}<\/span>\n    <span class=\"synSpecial\">}<\/span>\n  <span class=\"synSpecial\">}<\/span>\n<span class=\"synSpecial\">}<\/span>\n<\/pre>\n<pre class=\"code lang-typescript\" data-lang=\"typescript\" data-unlink=\"\">\n<span class=\"synIdentifier\">const<\/span> formatTextStyle = (<span class=\"synPreProc\">value<\/span>:<span class=\"synPreProc\"> <\/span><span class=\"synType\">any<\/span><span class=\"synStatement\">,<\/span><span class=\"synPreProc\"> isJapanese<\/span>:<span class=\"synPreProc\"> <\/span><span class=\"synType\">boolean<\/span>):<span class=\"synPreProc\"> <\/span><span class=\"synType\">string<\/span><span class=\"synPreProc\"> <\/span><span class=\"synType\">=&gt;<\/span> <span class=\"synIdentifier\">{<\/span>\n  \n  <span class=\"synIdentifier\">const<\/span> fontWeight = value.fontWeight\n    ? <span class=\"synConstant\">`fontWeight: FontWeight.w<\/span><span class=\"synStatement\">${<\/span>adjustedWeight<span class=\"synStatement\">}<\/span><span class=\"synConstant\">,`<\/span>\n    : <span class=\"synConstant\">null<\/span>;\n\n  \n  <span class=\"synIdentifier\">const<\/span> fontFamily = isJapanese ? <span class=\"synConstant\">`fontFamily: 'Hiragino Sans',`<\/span> : <span class=\"synConstant\">null<\/span>;\n\n  \n  <span class=\"synIdentifier\">const<\/span> height = value.lineHeight &amp;&amp; value.fontSize\n    ? <span class=\"synConstant\">`height: <\/span><span class=\"synStatement\">${<\/span>(value.lineHeight \/ value.fontSize).toFixed(<span class=\"synConstant\">2<\/span>)<span class=\"synStatement\">}<\/span><span class=\"synConstant\">,`<\/span>\n    : <span class=\"synConstant\">null<\/span>;\n  \n<span class=\"synIdentifier\">}<\/span>\n<\/pre>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">\n<span class=\"synStatement\">class<\/span> ZNMTypography {\n  <span class=\"synIdentifier\">static<\/span> TextStyle get jpBodyM {\n    <span class=\"synStatement\">return<\/span> <span class=\"synStatement\">const<\/span> TextStyle(\n      fontSize: 14,\n      fontWeight: FontWeight.w400,\n      fontFamily: <span class=\"synConstant\">'Hiragino Sans'<\/span>,\n      height: 1.50,  \n    );\n  }\n}\n<\/pre>\n<h3 id=\"\u5b9f\u88c5\u30ac\u30a4\u30c9\u30e9\u30a4\u30f3\">\u5b9f\u88c5\u30ac\u30a4\u30c9\u30e9\u30a4\u30f3<\/h3>\n<p>\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u306e\u5c0e\u5165\u306b\u3088\u308a\u3001\u30cf\u30fc\u30c9\u30b3\u30fc\u30c9\u3055\u308c\u305f\u5024\u304b\u3089\u610f\u5473\u306e\u3042\u308b\u540d\u524d\u3078\u306e\u79fb\u884c\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<h4 id=\"Before\u30cf\u30fc\u30c9\u30b3\u30fc\u30c9\u3055\u308c\u305f\u5024\">Before\uff1a\u30cf\u30fc\u30c9\u30b3\u30fc\u30c9\u3055\u308c\u305f\u5024<\/h4>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">Container(\n  decoration: BoxDecoration(\n    color: Color(0xFFFFFFFF),           \n    borderRadius: BorderRadius.circular(8), \n  ),\n  child: Text(\n    <span class=\"synConstant\">'\u30e1\u30c3\u30bb\u30fc\u30b8'<\/span>,\n    style: TextStyle(\n      fontSize: 14,                     \n      color: Color(0xFF2D2D2D),         \n    ),\n  ),\n)\n<\/pre>\n<h4 id=\"After\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u3092\u4f7f\u7528\">After\uff1a\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u3092\u4f7f\u7528<\/h4>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">Container(\n  decoration: BoxDecoration(\n    color: ZNMColors.surfacePrimary,        \n    borderRadius: BorderRadius.circular(ZNMRadius.m), \n  ),\n  child: Text(\n    <span class=\"synConstant\">'\u30e1\u30c3\u30bb\u30fc\u30b8'<\/span>,\n    style: ZNMTypography.jpBodyM.copyWith(  \n      color: ZNMColors.textPrimary,         \n    ),\n  ),\n)\n<\/pre>\n<ul>\n<li>\u30bb\u30de\u30f3\u30c6\u30a3\u30c3\u30af\u306a\u30c8\u30fc\u30af\u30f3\uff08<code>textPrimary<\/code>\uff09\u3092\u4f7f\u7528\u3057\u3001\u5177\u4f53\u7684\u306a\u5024\uff08<code>gray900<\/code>\uff09\u306f\u907f\u3051\u308b<\/li>\n<li>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u5358\u4f4d\u3067\u30b9\u30bf\u30a4\u30eb\u3092\u9069\u7528\uff08<code>ZNMTypography.jpHeadingM<\/code>\u3092\u305d\u306e\u307e\u307e\u4f7f\u7528\uff09<\/li>\n<li>\u7279\u6b8a\u306a\u30b1\u30fc\u30b9\u4ee5\u5916\u3067\u306f\u65e2\u5b58\u30c8\u30fc\u30af\u30f3\u306e\u5024\u3092\u5909\u66f4\u3057\u306a\u3044<\/li>\n<\/ul>\n<p>\u3053\u306e\u4ed5\u7d44\u307f\u306b\u3088\u3063\u3066\u3001\u30b3\u30fc\u30c9\u306e\u54c1\u8cea\u5411\u4e0a\u3060\u3051\u3067\u306a\u304f\u3001\u30c1\u30fc\u30e0\u306e\u50cd\u304d\u65b9\u306b\u3082\u30dd\u30b8\u30c6\u30a3\u30d6\u306a\u5909\u5316\u304c\u751f\u307e\u308c\u307e\u3057\u305f\u3002<\/p>\n<p>\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u306e\u81ea\u52d5\u5909\u63db\u3067\u3001Figma\u306e\u5b9a\u7fa9\u3068\u5b9f\u88c5\u30b3\u30fc\u30c9\u304c1:1\u3067\u540c\u671f\u3055\u308c\u307e\u3059\u3002\u30ec\u30d3\u30e5\u30fc\u3067\u306f\u300cFigma\u306e\u30bb\u30de\u30f3\u30c6\u30a3\u30c3\u30af\u540d\u3068\u4e00\u81f4\u3059\u308b\u30c8\u30fc\u30af\u30f3\u304c\u9069\u7528\u3055\u308c\u3066\u3044\u308b\u304b\u300d\u3092\u57fa\u6e96\u306b\u3001\u30a8\u30f3\u30b8\u30cb\u30a2\u304b\u3089\u30c7\u30b6\u30a4\u30ca\u30fc\u3078\u610f\u898b\u4ea4\u63db\u304c\u81ea\u7136\u306b\u884c\u304d\u4ea4\u3046\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<p>\u305f\u3068\u3048\u3070UI\u5b9f\u88c5\u6642\u3001\u30a8\u30f3\u30b8\u30cb\u30a2\u306f\u30c8\u30fc\u30af\u30f3\u306e\u578b\u4ed8\u304d\u30b3\u30fc\u30c9\u3092\u524d\u63d0\u306b\u4f5c\u696d\u3059\u308b\u305f\u3081\u3001Figma\u3068\u7167\u3089\u3057\u5408\u308f\u305b\u308b\u904e\u7a0b\u3067\u300c\u3053\u306eUI\u3001\u30c8\u30fc\u30af\u30f3\u304c\u9069\u7528\u3055\u308c\u3066\u3044\u306a\u3044\u304b\u3082\u300d\u3068\u3044\u3063\u305f\u9055\u548c\u611f\u306b\u3059\u3050\u6c17\u3065\u304f\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u30c1\u30fc\u30e0\u5168\u4f53\u3067\u30c8\u30fc\u30af\u30f3\u3092\u4f7f\u3046\u306e\u304c\u524d\u63d0\u3068\u3044\u3046\u5171\u901a\u8a8d\u8b58\u304c\u80b2\u307e\u308c\u3001\u30c7\u30b6\u30a4\u30ca\u30fc\u5074\u3082\u4e00\u8cab\u6027\u3092\u610f\u8b58\u3057\u305f\u8a2d\u8a08\u304c\u3057\u3084\u3059\u304f\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<h2 id=\"2-\u518d\u5229\u7528\u53ef\u80fd\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u6574\u5099\">2. \u518d\u5229\u7528\u53ef\u80fd\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u6574\u5099<\/h2>\n<p>\u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u3060\u3051\u3067\u306f\u3001\u4e00\u8cab\u6027\u306e\u3042\u308bUI\u3092\u69cb\u7bc9\u3059\u308b\u306b\u306f\u4e0d\u5341\u5206\u3067\u3057\u305f\u3002\u540c\u3058\u30c8\u30fc\u30af\u30f3\u3092\u4f7f\u3063\u3066\u3044\u3066\u3082\u3001\u5b9f\u88c5\u8005\u306b\u3088\u3063\u3066\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u69cb\u9020\u3084\u30a4\u30f3\u30bf\u30e9\u30af\u30b7\u30e7\u30f3\u304c\u7570\u306a\u308c\u3070\u3001\u7d50\u5c40\u306f\u30d0\u30e9\u30d0\u30e9\u306aUI\u306b\u306a\u3063\u3066\u3057\u307e\u3044\u307e\u3059\u3002<\/p>\n<p>\u305d\u3053\u3067\u79c1\u305f\u3061\u306f\u3001\u30a2\u30d7\u30ea\u5168\u4f53\u3067\u4f7f\u7528\u3059\u308b50\u4ee5\u4e0a\u306eUI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u3001<strong>\u30c9\u30e1\u30a4\u30f3\u306b\u4f9d\u5b58\u3057\u306a\u3044\u6c4e\u7528\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<\/strong>\u3068\u3057\u3066\u4f53\u7cfb\u7684\u306b\u6574\u5099\u3057\u307e\u3057\u305f\u3002<\/p>\n<h3 id=\"\u306a\u305c\u30c9\u30e1\u30a4\u30f3\u306b\u4f9d\u5b58\u3057\u306a\u3044\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304c\u91cd\u8981\u306a\u306e\u304b\">\u306a\u305c\u30c9\u30e1\u30a4\u30f3\u306b\u4f9d\u5b58\u3057\u306a\u3044\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304c\u91cd\u8981\u306a\u306e\u304b<\/h3>\n<p>\u30de\u30c3\u30c1\u30f3\u30b0\u30a2\u30d7\u30ea\u306b\u306f\u300c\u30e6\u30fc\u30b6\u30fc\u300d\u300c\u30e1\u30c3\u30bb\u30fc\u30b8\u300d\u300c\u3044\u3044\u306d\u300d\u3068\u3044\u3063\u305f\u56fa\u6709\u306e\u30c9\u30e1\u30a4\u30f3\u6982\u5ff5\u304c\u3042\u308a\u307e\u3059\u3002\u3057\u304b\u3057\u3001UI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304c\u3053\u308c\u3089\u306e\u6982\u5ff5\u306b\u76f4\u63a5\u4f9d\u5b58\u3057\u3066\u3057\u307e\u3046\u3068\u3001\u4ee5\u4e0b\u306e\u554f\u984c\u304c\u751f\u3058\u307e\u3059\u3002<\/p>\n<ul>\n<li><strong>\u518d\u5229\u7528\u6027\u304c\u4f4e\u4e0b<\/strong> -\u300c\u30e6\u30fc\u30b6\u30fc\u5c02\u7528\u30dc\u30bf\u30f3\u300d\u306f\u4ed6\u306e\u5834\u6240\u3067\u4f7f\u3048\u306a\u3044<\/li>\n<li><strong>\u30c6\u30b9\u30c8\u304c\u8907\u96d1<\/strong> &#8211; \u30c9\u30e1\u30a4\u30f3\u30ed\u30b8\u30c3\u30af\u306e\u30e2\u30c3\u30af\u304c\u5fc5\u8981\u306b\u306a\u308b<\/li>\n<li><strong>\u5909\u66f4\u306e\u5f71\u97ff\u7bc4\u56f2\u304c\u5e83\u3044<\/strong> &#8211; \u30c9\u30e1\u30a4\u30f3\u30e2\u30c7\u30eb\u306e\u5909\u66f4\u304cUI\u5168\u4f53\u306b\u6ce2\u53ca<\/li>\n<\/ul>\n<p>\u305d\u3053\u3067\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u5c64\u3067\u306f<strong>\u30d7\u30ea\u30df\u30c6\u30a3\u30d6\u306a\u578b<\/strong>\uff08String\u3001bool\u3001VoidCallback\u306a\u3069\uff09\u306e\u307f\u3092\u6271\u3044\u3001\u30c9\u30e1\u30a4\u30f3\u30e2\u30c7\u30eb\u3068\u306e\u5909\u63db\u306f\u5229\u7528\u5074\u3067\u884c\u3046\u8a2d\u8a08\u306b\u3057\u307e\u3057\u305f\u3002<\/p>\n<h3 id=\"\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u968e\u5c64\u69cb\u9020\">\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u968e\u5c64\u69cb\u9020<\/h3>\n<pre class=\"code\" data-lang=\"\" data-unlink=\"\">packages\/cores\/designsystem\/lib\/components\/\n\u251c\u2500\u2500 button\/          # \u30dc\u30bf\u30f3\u7cfb\uff08ZNMButton\u3001ZNMActionButton \u306a\u3069\uff09\n\u251c\u2500\u2500 card\/            # \u30ab\u30fc\u30c9\u7cfb\n\u251c\u2500\u2500 dialog\/          # \u30c0\u30a4\u30a2\u30ed\u30b0\u3001\u30e2\u30fc\u30c0\u30eb\n\u251c\u2500\u2500 input\/           # \u30c6\u30ad\u30b9\u30c8\u5165\u529b\u3001\u691c\u7d22\u30d0\u30fc\n\u251c\u2500\u2500 message\/         # \u30e1\u30c3\u30bb\u30fc\u30b8\u8868\u793a\uff08\u5439\u304d\u51fa\u3057\u3001\u65e5\u4ed8\u8868\u793a\u306a\u3069\uff09\n\u251c\u2500\u2500 navigation_bar\/  # \u30ca\u30d3\u30b2\u30fc\u30b7\u30e7\u30f3\u30d0\u30fc\n\u251c\u2500\u2500 row\/             # \u30ea\u30b9\u30c8\u884c\u3001\u30c1\u30a7\u30c3\u30af\u30dc\u30c3\u30af\u30b9\u3001\u30e9\u30b8\u30aa\u30dc\u30bf\u30f3\n\u2514\u2500\u2500 ...              # \u305d\u306e\u4ed640\u4ee5\u4e0a\u306e\u30ab\u30c6\u30b4\u30ea<\/pre>\n<p>\u5404\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306f\u3001Figma\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u968e\u5c64\u30681:1\u3067\u5bfe\u5fdc\u3057\u3066\u3044\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u30c7\u30b6\u30a4\u30ca\u30fc\u3068\u30a8\u30f3\u30b8\u30cb\u30a2\u304c\u300c<code>ZNMButton<\/code>\u306e<code>primary<\/code>\u3067<code>large<\/code>\u30b5\u30a4\u30ba\u300d\u3068\u3044\u3063\u305f\u5171\u901a\u8a00\u8a9e\u3067\u4f1a\u8a71\u3067\u304d\u307e\u3059\u3002<\/p>\n<h3 id=\"\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u5b9f\u88c5\u4f8b\">\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u5b9f\u88c5\u4f8b<\/h3>\n<h4 id=\"1-\u30dc\u30bf\u30f3\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8---\u67d4\u8edf\u6027\u3068\u4e00\u8cab\u6027\u306e\u4e21\u7acb\">1. \u30dc\u30bf\u30f3\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8 &#8211; \u67d4\u8edf\u6027\u3068\u4e00\u8cab\u6027\u306e\u4e21\u7acb<\/h4>\n<p><figure class=\"figure-image figure-image-fotolife\" title=\"\"><span itemscope=\"\" itemtype=\"http:\/\/schema.org\/Photograph\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20251001\/20251001131729.png\" width=\"1200\" height=\"1088\" loading=\"lazy\" title=\"\" class=\"hatena-fotolife\" itemprop=\"image\"\/><\/span><figcaption>Figma\u3067\u5b9a\u7fa9\u3055\u308c\u305fZNMButton\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u30d0\u30ea\u30a8\u30fc\u30b7\u30e7\u30f3\u3002<\/figcaption><\/figure>\n<\/p>\n<p>\u3053\u306eFigma\u30c7\u30b6\u30a4\u30f3\u3092\u57fa\u306b\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306bFlutter\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3068\u3057\u3066\u5b9f\u88c5\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">\n<span class=\"synStatement\">class<\/span> ZNMButton <span class=\"synStatement\">extends<\/span> HookWidget {\n  <span class=\"synIdentifier\">factory<\/span> ZNMButton({\n    required <span class=\"synType\">String<\/span> title,\n    required ZNMButtonColor color,    \n    required ZNMButtonSize size,      \n    required VoidCallback? onPressed,\n    <span class=\"synType\">bool<\/span> isWidthFlexible = <span class=\"synConstant\">false<\/span>,\n  }) {\n    \n  }\n\n  \n  <span class=\"synIdentifier\">factory<\/span> ZNMButton.icon({\n    required <span class=\"synType\">String<\/span> title,\n    required SvgGenImage svgImage,    \n    required ZNMButtonColor color,\n    required ZNMButtonSize size,\n    required VoidCallback? onPressed,\n  }) {\n    \n  }\n}\n<\/pre>\n<h4 id=\"\u8a2d\u8a08\u306e\u30dd\u30a4\u30f3\u30c8\">\u8a2d\u8a08\u306e\u30dd\u30a4\u30f3\u30c8<\/h4>\n<ul>\n<li><strong>Enum\u306b\u3088\u308b\u9078\u629e\u80a2\u306e\u5236\u9650<\/strong> &#8211; \u7121\u79e9\u5e8f\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3092\u9632\u3050<\/li>\n<li><strong>\u30d5\u30a1\u30af\u30c8\u30ea\u30b3\u30f3\u30b9\u30c8\u30e9\u30af\u30bf<\/strong> &#8211; \u30d0\u30ea\u30a8\u30fc\u30b7\u30e7\u30f3\u3092\u660e\u78ba\u306b\u5b9a\u7fa9<\/li>\n<li><strong>\u30d7\u30ea\u30df\u30c6\u30a3\u30d6\u306a\u578b<\/strong> &#8211; \u30c9\u30e1\u30a4\u30f3\u30e2\u30c7\u30eb\u306b\u4f9d\u5b58\u3057\u306a\u3044<\/li>\n<\/ul>\n<h3 id=\"\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u958b\u767a\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\">\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u958b\u767a\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fc<\/h3>\n<h4 id=\"1-Figma\u304b\u3089\u306e\u4ed5\u69d8\u78ba\u8a8d\">1. Figma\u304b\u3089\u306e\u4ed5\u69d8\u78ba\u8a8d<\/h4>\n<p>\u30c7\u30b6\u30a4\u30ca\u30fc\u304cFigma\u3067\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u5b9a\u7fa9\u3059\u308b\u969b\u3001\u4ee5\u4e0b\u306e\u60c5\u5831\u3092\u660e\u78ba\u306b\u3057\u307e\u3059\u3002<\/p>\n<ul>\n<li><strong>\u30d0\u30ea\u30a8\u30fc\u30b7\u30e7\u30f3<\/strong> &#8211; \u30ab\u30e9\u30fc\u3001\u30b5\u30a4\u30ba\u3001\u72b6\u614b\u306e\u30d1\u30bf\u30fc\u30f3<\/li>\n<li><strong>\u30a4\u30f3\u30bf\u30e9\u30af\u30b7\u30e7\u30f3<\/strong> &#8211; \u30bf\u30c3\u30d7\u3001\u9577\u62bc\u3057\u3001\u30b9\u30ef\u30a4\u30d7\u306a\u3069\u306e\u6319\u52d5<\/li>\n<li><strong>\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3<\/strong> &#8211; \u9077\u79fb\u6642\u306e\u52d5\u304d\u3001\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u8868\u793a<\/li>\n<\/ul>\n<h4 id=\"2-\u6c4e\u7528\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3068\u3057\u3066\u306e\u5b9f\u88c5\">2. \u6c4e\u7528\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3068\u3057\u3066\u306e\u5b9f\u88c5<\/h4>\n<p>\u5225\u306e\u4f8b\u3068\u3057\u3066\u3001\u30ab\u30fc\u30c9\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u5b9f\u88c5\u3092\u898b\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u3053\u3061\u3089\u3082\u30c9\u30e1\u30a4\u30f3\u306b\u4f9d\u5b58\u305b\u305a\u3001\u6c4e\u7528\u7684\u306b\u4f7f\u3048\u308b\u3088\u3046\u8a2d\u8a08\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">\n<span class=\"synStatement\">class<\/span> ZNMCard <span class=\"synStatement\">extends<\/span> StatelessWidget {\n  <span class=\"synStatement\">const<\/span> ZNMCard({\n    required Widget child,\n    Color? backgroundColor,\n    <span class=\"synType\">double<\/span>? elevation,\n    VoidCallback? onTap,\n  });\n  \n  @override\n  Widget build(BuildContext context) {\n    <span class=\"synStatement\">return<\/span> Card(\n      color: backgroundColor ?? ZNMColors.surfacePrimary,\n      elevation: elevation ?? ZNMShadows.cardElevation,\n      shape: RoundedRectangleBorder(\n        borderRadius: BorderRadius.circular(ZNMRadius.m),\n      ),\n      child: InkWell(\n        onTap: onTap,\n        borderRadius: BorderRadius.circular(ZNMRadius.m),\n        child: child,\n      ),\n    );\n  }\n}\n<\/pre>\n<p>\u3053\u306e\u4f53\u7cfb\u7684\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u6574\u5099\u306b\u3088\u308a\u3001\u65b0\u3057\u3044\u753b\u9762\u3092\u5b9f\u88c5\u3059\u308b\u969b\u3082\u3001\u65e2\u5b58\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u7d44\u307f\u5408\u308f\u305b\u308b\u3060\u3051\u3067\u3001\u4e00\u8cab\u6027\u306e\u3042\u308bUI\u3092\u7d20\u65e9\u304f\u69cb\u7bc9\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<h3 id=\"Widgetbook\u3068\u306f\">Widgetbook\u3068\u306f<\/h3>\n<p><a target=\"_blank\" href=\"https:\/\/www.widgetbook.io\/\">Widgetbook<\/a>\u306f\u3001Flutter\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u7528\u306eUI\u30ab\u30bf\u30ed\u30b0\u30c4\u30fc\u30eb\u3067\u3059\u3002Storybook\u306eFlutter\u7248\u3068\u3082\u8a00\u3048\u308b\u5b58\u5728\u3067\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u72ec\u7acb\u3057\u305f\u74b0\u5883\u3067\u30d7\u30ec\u30d3\u30e5\u30fc\u30fb\u30c6\u30b9\u30c8\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u79c1\u305f\u3061\u304cWidgetbook\u3092\u9078\u3093\u3060\u7406\u7531\u306f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u7279\u5fb4\u304c\u3042\u308b\u305f\u3081\u3067\u3059\u3002<\/p>\n<ol>\n<li>\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u306e\u78ba\u8a8d &#8211; \u30c7\u30b6\u30a4\u30ca\u30fc\u3082\u30a2\u30d7\u30ea\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u305b\u305a\u306b\u78ba\u8a8d\u53ef\u80fd<\/li>\n<li>\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u64cd\u4f5c &#8211; \u30d1\u30e9\u30e1\u30fc\u30bf\u3092\u52d5\u7684\u306b\u5909\u66f4\u3057\u3066\u6319\u52d5\u3092\u78ba\u8a8d<\/li>\n<li>\u30c7\u30d0\u30a4\u30b9\u30d7\u30ec\u30d3\u30e5\u30fc &#8211; iPhone\u3001Android\u3001iPad\u306a\u3069\u69d8\u3005\u306a\u753b\u9762\u30b5\u30a4\u30ba\u3067\u78ba\u8a8d<\/li>\n<li>\u81ea\u52d5\u751f\u6210 &#8211; \u30a2\u30ce\u30c6\u30fc\u30b7\u30e7\u30f3\u30d9\u30fc\u30b9\u3067\u30ab\u30bf\u30ed\u30b0\u3092\u81ea\u52d5\u69cb\u7bc9<\/li>\n<\/ol>\n<p>\u5b9f\u969b\u306eWidgetbook\u30ab\u30bf\u30ed\u30b0\u306e\u753b\u9762\u3067\u3059\u3002\u5de6\u5074\u306b\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u30c4\u30ea\u30fc\u3001\u4e2d\u592e\u306b\u30d7\u30ec\u30d3\u30e5\u30fc\u3001\u53f3\u5074\u306bKnobs\u30d1\u30cd\u30eb\u304c\u8868\u793a\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<p><figure class=\"figure-image figure-image-fotolife\" title=\"\"><span itemscope=\"\" itemtype=\"http:\/\/schema.org\/Photograph\"><img decoding=\"async\" src=\"https:\/\/cdn-ak.f.st-hatena.com\/images\/fotolife\/v\/vasilyjp\/20251001\/20251001131743.png\" width=\"1200\" height=\"660\" loading=\"lazy\" title=\"\" class=\"hatena-fotolife\" itemprop=\"image\"\/><\/span><figcaption>Widgetbook\u30ab\u30bf\u30ed\u30b0\u306e\u753b\u9762\u69cb\u6210\uff08\u5de6\uff1a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u30c4\u30ea\u30fc\u3001\u4e2d\u592e\uff1a\u30d7\u30ec\u30d3\u30e5\u30fc\u3001\u53f3\uff1aKnobs\u30d1\u30cd\u30eb\uff09\u3002<\/figcaption><\/figure>\n<\/p>\n<h3 id=\"ZOZO\u30de\u30c3\u30c1\u3067\u306e\u5b9f\u88c5\">ZOZO\u30de\u30c3\u30c1\u3067\u306e\u5b9f\u88c5<\/h3>\n<h4 id=\"\u30ab\u30bf\u30ed\u30b0\u30a2\u30d7\u30ea\u306e\u69cb\u6210\">\u30ab\u30bf\u30ed\u30b0\u30a2\u30d7\u30ea\u306e\u69cb\u6210<\/h4>\n<pre class=\"code\" data-lang=\"\" data-unlink=\"\">apps\/catalog\/\n\u251c\u2500\u2500 lib\/\n\u2502   \u251c\u2500\u2500 main.dart              # Widgetbook\u30a2\u30d7\u30ea\u306e\u30a8\u30f3\u30c8\u30ea\u30fc\u30dd\u30a4\u30f3\u30c8\n\u2502   \u2514\u2500\u2500 use_case\/\n\u2502       \u251c\u2500\u2500 cores\/\n\u2502       \u2502   \u2514\u2500\u2500 designsystem\/\n\u2502       \u2502       \u2514\u2500\u2500 components\/ # 20\u30ab\u30c6\u30b4\u30ea\u30fb50\u4ee5\u4e0a\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\n\u2502       \u2514\u2500\u2500 features\/          # \u5404\u6a5f\u80fd\u306eUI\n\u251c\u2500\u2500 goldens\/                   # \u30b4\u30fc\u30eb\u30c7\u30f3\u30c6\u30b9\u30c8\u7528\u306e\u30b9\u30ca\u30c3\u30d7\u30b7\u30e7\u30c3\u30c8\n\u2514\u2500\u2500 test\/                      # \u30d3\u30b8\u30e5\u30a2\u30eb\u30ea\u30b0\u30ec\u30c3\u30b7\u30e7\u30f3\u30c6\u30b9\u30c8<\/pre>\n<h4 id=\"Widgetbook\u30a2\u30d7\u30ea\u306e\u8a2d\u5b9a\">Widgetbook\u30a2\u30d7\u30ea\u306e\u8a2d\u5b9a<\/h4>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">\n@App()\n<span class=\"synStatement\">class<\/span> WidgetbookApp <span class=\"synStatement\">extends<\/span> StatelessWidget {\n  @override\n  Widget build(BuildContext context) {\n    <span class=\"synStatement\">return<\/span> Widgetbook.material(\n      directories: directories,  \n      addons: [\n        \n        MaterialThemeAddon(\n          themes: [\n            WidgetbookTheme(name: <span class=\"synConstant\">'Light'<\/span>, data: lightTheme()),\n            WidgetbookTheme(name: <span class=\"synConstant\">'Dark'<\/span>, data: darkTheme()),\n          ],\n        ),\n        \n        ViewportAddon([\n          IosViewports.iPhone13,\n          IosViewports.iPhoneSE,\n          IosViewports.iPad,\n          ...AndroidViewports.phones,\n        ]),\n        \n        InspectorAddon(),\n        \n        LocalizationAddon(\n          locales: [...DesignSystemL10n.supportedLocales],\n          localizationsDelegates: [...],\n        ),\n      ],\n    );\n  }\n}\n<\/pre>\n<h4 id=\"\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306eUse-Case\u5b9f\u88c5\u4f8b\">\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306eUse Case\u5b9f\u88c5\u4f8b<\/h4>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">\n@UseCase(name: <span class=\"synConstant\">'ZNMButton'<\/span>, type: ZNMButton)\nWidget znmButtonUseCase(BuildContext context) {\n  <span class=\"synStatement\">return<\/span> Scaffold(\n    appBar: AppBar(title: <span class=\"synStatement\">const<\/span> Text(<span class=\"synConstant\">'ZNMButton Sample'<\/span>)),\n    body: SingleChildScrollView(\n      child: Column(\n        children: ZNMButtonSize.values.map((size) =&gt;\n          ZNMButton(\n            \n            color: context.knobs.dropdown(\n              label: <span class=\"synConstant\">'color'<\/span>,\n              options: ZNMButtonColor.values,\n              initialOption: ZNMButtonColor.primary,\n            ),\n            size: size,\n            title: context.knobs.string(\n              label: <span class=\"synConstant\">'title'<\/span>,\n              initialValue: <span class=\"synConstant\">'\u30c6\u30ad\u30b9\u30c8'<\/span>,\n            ),\n            onPressed: context.knobs.boolean(label: <span class=\"synConstant\">'enabled'<\/span>)\n              ? () =&gt; log(<span class=\"synConstant\">'pressed'<\/span>)\n              : <span class=\"synStatement\">null<\/span>,\n          ),\n        ).toList(),\n      ),\n    ),\n  );\n}\n<\/pre>\n<h3 id=\"Widgetbook\u306e\u6d3b\u7528\u52b9\u679c\">Widgetbook\u306e\u6d3b\u7528\u52b9\u679c<\/h3>\n<h4 id=\"1-\u5b9f\u88c5\u524d\u306e\u78ba\u8a8d\u30d5\u30ed\u30fc\">1. \u5b9f\u88c5\u524d\u306e\u78ba\u8a8d\u30d5\u30ed\u30fc<\/h4>\n<p>\u65b0\u3057\u3044\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u5b9f\u88c5\u3059\u308b\u969b\u306e\u78ba\u8a8d\u30d5\u30ed\u30fc\u304c\u78ba\u7acb\u3055\u308c\u307e\u3057\u305f\u3002<\/p>\n<ol>\n<li>\u30c7\u30b6\u30a4\u30ca\u30fc\u304cFigma\u3067\u4f5c\u6210<\/li>\n<li>\u30a8\u30f3\u30b8\u30cb\u30a2\u304c\u5b9f\u88c5<\/li>\n<li>Widgetbook\u3067\u78ba\u8a8d &#8211; \u30c7\u30b6\u30a4\u30ca\u30fc\u304c\u30d6\u30e9\u30a6\u30b6\u3067\u6319\u52d5\u3092\u78ba\u8a8d<\/li>\n<li>\u30d5\u30a3\u30fc\u30c9\u30d0\u30c3\u30af\u53cd\u6620 &#8211; \u305d\u306e\u5834\u3067\u8abf\u6574\u304c\u5fc5\u8981\u306a\u7b87\u6240\u3092\u7279\u5b9a<\/li>\n<\/ol>\n<h4 id=\"2-\u30d0\u30ea\u30a8\u30fc\u30b7\u30e7\u30f3\u306e\u7db2\u7f85\u7684\u306a\u78ba\u8a8d\">2. \u30d0\u30ea\u30a8\u30fc\u30b7\u30e7\u30f3\u306e\u7db2\u7f85\u7684\u306a\u78ba\u8a8d<\/h4>\n<pre class=\"code lang-dart\" data-lang=\"dart\" data-unlink=\"\">\n@UseCase(name: <span class=\"synConstant\">'All Variations'<\/span>, type: ZNMButton)\nWidget allVariationsUseCase(BuildContext context) {\n  <span class=\"synStatement\">return<\/span> GridView.builder(\n    gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(\n      crossAxisCount: 3,\n    ),\n    itemCount: ZNMButtonColor.values.length * ZNMButtonSize.values.length,\n    itemBuilder: (context, index) {\n      <span class=\"synStatement\">final<\/span> colorIndex = index ~\/ ZNMButtonSize.values.length;\n      <span class=\"synStatement\">final<\/span> sizeIndex = index % ZNMButtonSize.values.length;\n\n      <span class=\"synStatement\">return<\/span> ZNMButton(\n        color: ZNMButtonColor.values[colorIndex],\n        size: ZNMButtonSize.values[sizeIndex],\n        title: <span class=\"synConstant\">'Button'<\/span>,\n        onPressed: () {},\n      );\n    },\n  );\n}\n<\/pre>\n<h4 id=\"3-\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3068\u3057\u3066\u306e\u4fa1\u5024\">3. \u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3068\u3057\u3066\u306e\u4fa1\u5024<\/h4>\n<p>Widgetbook\u306f\u751f\u304d\u305f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3068\u3057\u3066\u6a5f\u80fd\u3057\u307e\u3059\u3002<\/p>\n<ul>\n<li>\u65b0\u30e1\u30f3\u30d0\u30fc\u306e\u30aa\u30f3\u30dc\u30fc\u30c7\u30a3\u30f3\u30b0 &#8211; UI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u5168\u5bb9\u3092\u628a\u63e1<\/li>\n<li>\u5b9f\u88c5\u8005\u306e\u53c2\u8003 &#8211; \u4f7f\u3044\u65b9\u3084\u5236\u7d04\u4e8b\u9805\u3092\u5b9f\u969b\u306b\u52d5\u304b\u3057\u3066\u78ba\u8a8d<\/li>\n<li>\u30c7\u30b6\u30a4\u30f3\u30ec\u30d3\u30e5\u30fc &#8211; \u5b9f\u88c5\u304c\u30c7\u30b6\u30a4\u30f3\u901a\u308a\u304b\u5373\u5ea7\u306b\u78ba\u8a8d<\/li>\n<\/ul>\n<h3 id=\"\u30c7\u30d7\u30ed\u30a4\u3068\u5171\u6709\">\u30c7\u30d7\u30ed\u30a4\u3068\u5171\u6709<\/h3>\n<p>Widgetbook\u306f\u30d6\u30e9\u30a6\u30b6\u3067\u52d5\u4f5c\u3059\u308b\u305f\u3081\u3001GitHub Pages\u306b\u30c7\u30d7\u30ed\u30a4\u3057\u3066\u793e\u5185\u3067\u5171\u6709\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"code lang-sh\" data-lang=\"sh\" data-unlink=\"\">\nflutter build web <span class=\"synSpecial\">--target<\/span> lib\/main.dart\n\n\n\n<\/pre>\n<p>\u3053\u308c\u306b\u3088\u308a\u3001\u6700\u65b0\u306eUI\u30ab\u30bf\u30ed\u30b0\u304c\u5e38\u306b\u30d6\u30e9\u30a6\u30b6\u304b\u3089\u30a2\u30af\u30bb\u30b9\u53ef\u80fd\u306a\u72b6\u614b\u3092\u4fdd\u3063\u3066\u3044\u307e\u3059\u3002\u30c7\u30b6\u30a4\u30ca\u30fc\u3068\u30a8\u30f3\u30b8\u30cb\u30a2\u306e\u4e21\u65b9\u304c\u3001URL\u3092\u958b\u304f\u3060\u3051\u3067\u6700\u65b0\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u78ba\u8a8d\u3067\u304d\u307e\u3059\u3002<\/p>\n<h2 id=\"\u307e\u3068\u3081\">\u307e\u3068\u3081<\/h2>\n<p>\u672c\u8a18\u4e8b\u3067\u306f\u3001\u30c7\u30b6\u30a4\u30f3\u3068\u5b9f\u88c5\u306e\u30ba\u30ec\u3092\u306a\u304f\u3059\u305f\u3081\u306b\u5c0e\u5165\u3057\u305f\u30c7\u30b6\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u3068\u3001\u305d\u306e\u5177\u4f53\u7684\u306a\u904b\u7528\u4f8b\u3092\u7d39\u4ecb\u3057\u307e\u3057\u305f\u3002\u4eca\u5f8c\u306f\u3001Figma MCP\u306a\u3069\u306e\u4ed5\u7d44\u307f\u3082\u53d6\u308a\u5165\u308c\u306a\u304c\u3089\u3001Figma\u304b\u3089\u306e\u5b9f\u88c5\u52b9\u7387\u3092\u3055\u3089\u306b\u9ad8\u3081\u3066\u3044\u304d\u305f\u3044\u3068\u8003\u3048\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>ZOZO\u3067\u306f\u3001\u4e00\u7dd2\u306b\u30b5\u30fc\u30d3\u30b9\u3092\u4f5c\u308a\u4e0a\u3052\u3066\u304f\u308c\u308b\u65b9\u3092\u52df\u96c6\u4e2d\u3067\u3059\u3002\u3054\u8208\u5473\u306e\u3042\u308b\u65b9\u306f\u3001\u4ee5\u4e0b\u306e\u30ea\u30f3\u30af\u304b\u3089\u305c\u3072\u3054\u5fdc\u52df\u304f\u3060\u3055\u3044\u3002<\/p>\n<p><iframe src=\"https:\/\/hatenablog-parts.com\/embed?url=https%3A%2F%2Fcorp.zozo.com%2Frecruit%2F\" title=\"\u63a1\u7528 - \u682a\u5f0f\u4f1a\u793eZOZO\" class=\"embed-card embed-webcard\" scrolling=\"no\" frameborder=\"0\" style=\"display: block; width: 100%; height: 155px; max-width: 500px; margin: 10px 0px;\" loading=\"lazy\"><\/iframe><cite class=\"hatena-citation\"><a target=\"_blank\" href=\"https:\/\/corp.zozo.com\/recruit\/\">corp.zozo.com<\/a><\/cite><\/p>\n<\/div>\n\n<br \/><a href=\"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token\">\u5143\u306e\u8a18\u4e8b\u3092\u78ba\u8a8d\u3059\u308b <\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\u306f\u3058\u3081\u306b \u3053\u3093\u306b\u3061\u306f\u3001\u65b0\u898f\u4e8b\u696d\u90e8\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30d6\u30ed\u30c3\u30af\u306e\u5b89\u571f\u7422\u6717\u3067\u3059\u3002\u666e\u6bb5\u306fZOZO\u30de\u30c3\u30c1\u306eFlutter\u30a2\u30d7\u30ea\u958b\u767a\u3092\u62c5\u5f53\u3057\u3066\u3044\u307e\u3059\u3002 ZOZO\u30de\u30c3\u30c1\u306f2025\u5e746\u6708\u306b\u30ea\u30ea\u30fc\u30b9\u3055\u308c\u305f\u3001\u30bc\u30ed\u304b\u3089\u7acb\u3061\u4e0a\u3052\u305f\u30de\u30c3\u30c1\u30f3\u30b0\u30a2\u30d7\u30ea\u3067 [&hellip;]","protected":false},"author":1,"featured_media":10066,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[4],"tags":[],"class_list":["post-10065","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-company-tec"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.6 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f - ZOZO TECH BLOG - \u30dd\u30b1\u30b3\u30f3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token\" \/>\n<meta property=\"og:locale\" content=\"ja_JP\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f - ZOZO TECH BLOG - \u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"og:description\" content=\"\u306f\u3058\u3081\u306b \u3053\u3093\u306b\u3061\u306f\u3001\u65b0\u898f\u4e8b\u696d\u90e8\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30d6\u30ed\u30c3\u30af\u306e\u5b89\u571f\u7422\u6717\u3067\u3059\u3002\u666e\u6bb5\u306fZOZO\u30de\u30c3\u30c1\u306eFlutter\u30a2\u30d7\u30ea\u958b\u767a\u3092\u62c5\u5f53\u3057\u3066\u3044\u307e\u3059\u3002 ZOZO\u30de\u30c3\u30c1\u306f2025\u5e746\u6708\u306b\u30ea\u30ea\u30fc\u30b9\u3055\u308c\u305f\u3001\u30bc\u30ed\u304b\u3089\u7acb\u3061\u4e0a\u3052\u305f\u30de\u30c3\u30c1\u30f3\u30b0\u30a2\u30d7\u30ea\u3067 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token\" \/>\n<meta property=\"og:site_name\" content=\"\u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"article:published_time\" content=\"2025-10-19T01:07:51+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1300\" \/>\n\t<meta property=\"og:image:height\" content=\"731\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"info@pokecon.jp\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u57f7\u7b46\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"info@pokecon.jp\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u63a8\u5b9a\u8aad\u307f\u53d6\u308a\u6642\u9593\" \/>\n\t<meta name=\"twitter:data2\" content=\"3\u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/10065\\\/\"},\"author\":{\"name\":\"info@pokecon.jp\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"headline\":\"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f &#8211; ZOZO TECH BLOG\",\"datePublished\":\"2025-10-19T01:07:51+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/10065\\\/\"},\"wordCount\":162,\"image\":{\"@id\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png\",\"articleSection\":[\"\u4f01\u696d\u30c6\u30c3\u30af\"],\"inLanguage\":\"ja\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/10065\\\/\",\"url\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token\",\"name\":\"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f - ZOZO TECH BLOG - \u30dd\u30b1\u30b3\u30f3\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png\",\"datePublished\":\"2025-10-19T01:07:51+00:00\",\"author\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"breadcrumb\":{\"@id\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token#breadcrumb\"},\"inLanguage\":\"ja\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token#primaryimage\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png\",\"contentUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/10\\\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png\",\"width\":1300,\"height\":731},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/techblog.zozo.com\\\/entry\\\/zozomatch-design-token#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u30db\u30fc\u30e0\",\"item\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f &#8211; ZOZO TECH BLOG\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\",\"name\":\"\u30dd\u30b1\u30b3\u30f3\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"ja\"},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\",\"name\":\"info@pokecon.jp\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"caption\":\"info@pokecon.jp\"},\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/author\\\/infopokecon-jp\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f - ZOZO TECH BLOG - \u30dd\u30b1\u30b3\u30f3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token","og_locale":"ja_JP","og_type":"article","og_title":"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f - ZOZO TECH BLOG - \u30dd\u30b1\u30b3\u30f3","og_description":"\u306f\u3058\u3081\u306b \u3053\u3093\u306b\u3061\u306f\u3001\u65b0\u898f\u4e8b\u696d\u90e8\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30d6\u30ed\u30c3\u30af\u306e\u5b89\u571f\u7422\u6717\u3067\u3059\u3002\u666e\u6bb5\u306fZOZO\u30de\u30c3\u30c1\u306eFlutter\u30a2\u30d7\u30ea\u958b\u767a\u3092\u62c5\u5f53\u3057\u3066\u3044\u307e\u3059\u3002 ZOZO\u30de\u30c3\u30c1\u306f2025\u5e746\u6708\u306b\u30ea\u30ea\u30fc\u30b9\u3055\u308c\u305f\u3001\u30bc\u30ed\u304b\u3089\u7acb\u3061\u4e0a\u3052\u305f\u30de\u30c3\u30c1\u30f3\u30b0\u30a2\u30d7\u30ea\u3067 [&hellip;]","og_url":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token","og_site_name":"\u30dd\u30b1\u30b3\u30f3","article_published_time":"2025-10-19T01:07:51+00:00","og_image":[{"width":1300,"height":731,"url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png","type":"image\/png"}],"author":"info@pokecon.jp","twitter_card":"summary_large_image","twitter_misc":{"\u57f7\u7b46\u8005":"info@pokecon.jp","\u63a8\u5b9a\u8aad\u307f\u53d6\u308a\u6642\u9593":"3\u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token#article","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/10065\/"},"author":{"name":"info@pokecon.jp","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"headline":"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f &#8211; ZOZO TECH BLOG","datePublished":"2025-10-19T01:07:51+00:00","mainEntityOfPage":{"@id":"https:\/\/pokecon.jp\/job\/10065\/"},"wordCount":162,"image":{"@id":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png","articleSection":["\u4f01\u696d\u30c6\u30c3\u30af"],"inLanguage":"ja"},{"@type":"WebPage","@id":"https:\/\/pokecon.jp\/job\/10065\/","url":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token","name":"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f - ZOZO TECH BLOG - \u30dd\u30b1\u30b3\u30f3","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/#website"},"primaryImageOfPage":{"@id":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token#primaryimage"},"image":{"@id":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png","datePublished":"2025-10-19T01:07:51+00:00","author":{"@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"breadcrumb":{"@id":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token#breadcrumb"},"inLanguage":"ja","potentialAction":[{"@type":"ReadAction","target":["https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token"]}]},{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token#primaryimage","url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png","contentUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/10\/https3A2F2Fcdn-ak.f.st-hatena.com2Fimages2Ffotolife2Fv2Fvasilyjp2F202510162F20251016120140.png","width":1300,"height":731},{"@type":"BreadcrumbList","@id":"https:\/\/techblog.zozo.com\/entry\/zozomatch-design-token#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u30db\u30fc\u30e0","item":"https:\/\/pokecon.jp\/job\/"},{"@type":"ListItem","position":2,"name":"Figma\u304b\u3089Flutter\u3078 \u2500\u2500 \u30c7\u30b6\u30a4\u30f3\u30c8\u30fc\u30af\u30f3\u81ea\u52d5\u5909\u63db\u3068UI\u30ab\u30bf\u30ed\u30b0\u3067\u5b9f\u88c5\u3092\u52a0\u901f &#8211; ZOZO TECH BLOG"}]},{"@type":"WebSite","@id":"https:\/\/pokecon.jp\/job\/#website","url":"https:\/\/pokecon.jp\/job\/","name":"\u30dd\u30b1\u30b3\u30f3","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/pokecon.jp\/job\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"ja"},{"@type":"Person","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997","name":"info@pokecon.jp","image":{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","caption":"info@pokecon.jp"},"url":"https:\/\/pokecon.jp\/job\/author\/infopokecon-jp\/"}]}},"_links":{"self":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/10065","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/comments?post=10065"}],"version-history":[{"count":1,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/10065\/revisions"}],"predecessor-version":[{"id":10067,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/10065\/revisions\/10067"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media\/10066"}],"wp:attachment":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media?parent=10065"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/categories?post=10065"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/tags?post=10065"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}