{"id":45264,"date":"2022-12-28T08:52:53","date_gmt":"2022-12-01T10:47:07","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/"},"modified":"2024-04-29T07:19:48","modified_gmt":"2024-04-28T23:19:48","slug":"45264-2","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/","title":{"rendered":""},"content":{"rendered":"<p>\u524d\u56de\u4f5c\u3063\u305faudio-bookmark\u306b\u3064\u3065\u304d\u3001Rust + React with Tauri \u3067\u307e\u305f\u307e\u305f\u81ea\u5df1\u6e80\u8db3\u30a2\u30d7\u30ea\u3092\u4f5c\u308a\u307e\u3057\u305f\uff01\u672c\u8a18\u4e8b\u3067\u306f\u3001\u4f5c\u54c1\u7d39\u4ecb\u306e\u3064\u3044\u3067\u306b\u3001Tauri\u306a\u3089\u3067\u306f\u306a\u6a5f\u80fd\u3082\u7d39\u4ecb\u3057\u3001\u30dd\u30a8\u30e0\u3067Tauri\u3092\u5e03\u6559\u3057\u3066\u3044\u304d\u307e\u3059\uff01<\/p>\n<p>\u4eca\u56de\u4f5c\u3063\u305f\u306e\u306f win-win-map (Windows&#8217; Windows Map)\u3068\u3044\u3046Windows\u7528\u30a6\u30a3\u30f3\u30c9\u30a6\u7ba1\u7406\u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\u30a2\u30d7\u30ea\u3067\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/3-0.gif\" alt=\"winwinmap_demo.gif\" \/><\/div>\n<p>\u30ea\u30dd\u30b8\u30c8\u30ea: https:\/\/github.com\/anotherhollow1125\/win-win-map<br \/>\n\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u30da\u30fc\u30b8: https:\/\/github.com\/anotherhollow1125\/win-win-map\/releases<\/p>\n<p>\u5236\u4f5c\u3057\u305f\u52d5\u6a5f\u306f\u5f8c\u307b\u3069\u7d39\u4ecb\u3057\u307e\u3059\u304c\u3001\u52d5\u753b\u306e\u901a\u308a\u3001\u672c\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u4f7f\u3046\u3053\u3068\u3067\u30de\u30a6\u30b9\u30dd\u30a4\u30f3\u30bf\u3001\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u30ad\u30fc\u7b49\u3067\u7279\u5b9a\u5ea7\u6a19\u306b\u53ec\u559a\u3057\u305f\u308a\u3001\u30de\u30c3\u30d7\u3067\u30c9\u30e9\u30c3\u30b0\u3059\u308b\u3053\u3068\u3067\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u52d5\u304b\u3057\u305f\u308a\u3067\u304d\u307e\u3059\u3002<\/p>\n<h1>\u306f\u3058\u3081\u306b<\/h1>\n<p>Rust\u5927\u597d\u304d\u306a\u5927\u5b66\u9662\u751f\u306enamnium\u3068\u7533\u3057\u307e\u3059\uff01\u3088\u304f\u7814\u7a76\u305d\u3063\u3061\u306e\u3051\u3067\u30a2\u30d7\u30ea\u5236\u4f5c\u3092\u3057\u305f\u308a\u767e\u5408\u30a2\u30cb\u30e1\u3092\u89b3\u305f\u308a\u3057\u3066\u3044\u307e\u3059\u3002(\u7814\u7a76\u3057\u308d)<\/p>\n<p>\u767e\u5408\u30a2\u30cb\u30e1\u3068\u3044\u3048\u30702022\u5e74\u306f\u8c4a\u4f5c\u3067\u3057\u305f\u306d\u3002\u307e\u3061\u30ab\u30c9\u307e\u305e\u304f2\u4e01\u76ee\u3001\u30ea\u30b3\u30ea\u30b9\u30fb\u30ea\u30b3\u30a4\u30eb\u3001\u6c34\u661f\u306e\u9b54\u5973\u3001\u307c\u3063\u3061\u30fb\u3056\u30fb\u308d\u3063\u304f\uff01\u3001\u2026\u7b49\u3005\u3001\u304a\u6c17\u306b\u5165\u308a\u4f5c\u54c1\u3070\u304b\u308a\u3067\u3059\u3002<\/p>\n<p>\u5b9f\u306f\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u754c\u9688\u3067\u3082\u5bc6\u304b\u306b\u4eba\u6c17\u3092\u96c6\u3081\u3066\u3044\u308b\u767e\u5408\u4f5c\u54c1\u304c\u3042\u308a\u307e\u3059\u2026\u2026\u305d\u3046\uff01\u305d\u308c\u3053\u305d\u304cGUI\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af Tauri\u306a\u306e\u3067\u3059\uff01<\/p>\n<h1>Tauri\u3068\u306f\uff1f<\/h1>\n<p>&nbsp;<\/p>\n<p>Tauri\u306f\u3001Rust\u88fd\u306e\u30af\u30ed\u30b9\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0GUI\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3067\u3059\u3002\u3053\u306e\u5148\u306e\u30dd\u30a8\u30e0\u3092\u8aad\u3080\u305f\u3081\u306b\u306f\u6b21\u306e3\u70b9\u3092\u6291\u3048\u3066\u304a\u3051\u3070\u5927\u4e08\u592b\u3067\u3059\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Tauri\u306f\u3001OS\u306eWebView\u3092\u547c\u3073\u51fa\u3059\u4ed5\u7d44\u307f\u3092\u4f7f\u3044\u3001Electron\u306e\u3088\u3046\u306a\u30c7\u30b9\u30af\u30c8\u30c3\u30d7\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u5b9f\u73fe\u3059\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">OS\u3068\u306e\u3084\u308a\u53d6\u308a\u3084\u91cd\u305f\u3044\u8a08\u7b97\u7b49\u306e\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u306fRust\u304c\u62c5\u5f53\u3059\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">GUI\u63cf\u753b\u7b49\u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306fTypeScript1\u304c\u62c5\u5f53\u3059\u308b<\/ul>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/14-0.png\" alt=\"\u821e\u53f0Tauri.png\" \/><\/div>\n<p>\u3088\u308a\u8a73\u7d30\u306a\u8aac\u660e\u306f\u4ee5\u524d\u66f8\u3044\u305f\u30cf\u30f3\u30ba\u30aa\u30f3\u8a18\u4e8b\u3067\u8aac\u660e\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n<div>\n<p>\u4ee5\u964d\u30dd\u30a8\u30e0\u3068\u30a2\u30d7\u30ea\u7d39\u4ecb\u304c\u7d9a\u304f\u306e\u3067Tauri\u306e\u6a5f\u80fd\u7d39\u4ecb\u306b\u98db\u3073\u305f\u3044\u65b9\u306f \u3053\u3061\u3089<\/p>\n<\/div>\n<h1>Tauri\u3068\u767e\u5408\u306e\u95a2\u4fc2\u6027\u306b\u95a2\u3059\u308b\u8003\u5bdf<\/h1>\n<p>\u300cTauri\u304c\u4eba\u6c17\u3092\u96c6\u3081\u3066\u3044\u308b\u767e\u5408\u4f5c\u54c1\uff1f\u4f55\u8a00\u3063\u3066\u308b\u3093\u3060\uff1f\u3053\u306e\u7b46\u8005\u300d\u3068\u601d\u308f\u308c\u305f\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002\u78ba\u304b\u306b\u300c\u4eba\u6c17\u3092\u96c6\u3081\u3066\u3044\u308b\u300d\u306f\u8a87\u5f35\u3067\u3057\u305f\u3002\u3057\u304b\u3057\u5b9f\u969b\u3001Tauri\u306f\u9b45\u529b\u7684\u306a\u767e\u5408\u30a2\u30cb\u30e1\u305f\u3061\u306b\u4f3c\u305f\u7279\u5fb4\u3092\u6301\u3063\u3066\u3044\u308b\u3093\u3067\u3059\u3002<\/p>\n<p>\u307e\u305e\u304f\u306e\u30b7\u30e3\u30df\u5b50\u3068\u9b54\u6cd5\u5c11\u5973\u6843\u3002\u9670\u30ad\u30e3\u306e\u307c\u3063\u3061\u3068\u967d\u30ad\u30e3\u306e\u559c\u591a\u3061\u3083\u3093\u3002\u7834\u5929\u8352\u306a\u5343\u675f\u3068\u771f\u9762\u76ee\u306a\u305f\u304d\u306a\u3002\u6700\u8fd1\u4eba\u6c17\u306a\u767e\u5408\u4f5c\u54c1\u306f\u5bfe\u7167\u7684\u306a2\u4eba\u306e\u30d0\u30c7\u30a3\u7269\u306a\u5074\u9762\u3082\u3042\u308a\u3001\u305d\u306e\u5bfe\u7167\u7684\u306a\u3053\u3068\u3092\u8d77\u56e0\u3068\u3059\u308b\u30a4\u30d9\u30f3\u30c8\u304c\u7269\u8a9e\u3092\u5f69\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>Tauri\u306b\u3082\u3053\u306e\u69cb\u9020\u304c\u8a8d\u3081\u3089\u308c\u308b\u306e\u3067\u3059\u3002\u578b\u306b\u61a7\u308c\u306a\u304c\u3089\u578b\u306b\u6075\u307e\u308c\u306a\u304b\u3063\u305f(\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30e9\u6b62\u307e\u308a\u306e)\u4eba\u6c17\u8005TypeScript\u3068\u3001\u578b\u306b\u3081\u3061\u3083\u304f\u3061\u3083\u6075\u307e\u308c\u306a\u304c\u3089\u3082\u5b8c\u74a7\u3055\u3086\u3048\u306b(\u96e3\u3057\u3044\u305b\u3044\u3067\u3001\u958b\u767a\u8005\u304b\u3089)\u76f8\u624b\u306b\u3055\u308c\u306a\u3044Rust\u20262\u4eba\u304c\u5354\u529b\u3057\u3066\u9b45\u529b\u7684\u306a\u30c7\u30b9\u30af\u30c8\u30c3\u30d7\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u308b\u2026\u2026Tauri\u306f\u3001\u307e\u308b\u3067\u73fe\u5728\u4f73\u5883\u3092\u8fce\u3048\u3066\u3044\u308b\u767e\u5408\u30a2\u30cb\u30e12\u3055\u306a\u304c\u3089\u306e\u3042\u3089\u3059\u3058\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>Rust\u306f\u30b7\u30b9\u30c6\u30e0\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u8a00\u8a9e\u3068\u3057\u3066\u306e\u5730\u4f4d\u306f\u78ba\u7acb\u3057\u3064\u3064\u3042\u308b\u4e00\u65b9\u3001GUI\u30a2\u30d7\u30ea\u5236\u4f5c\u306e\u624b\u6bb5\u3068\u3057\u3066\u306f\u5f31\u3044\u306e\u304c\u73fe\u5b9f\u3067\u3059\u3002\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u4ee5\u5916\u3067\u306e\u5546\u696d\u7684\u4fa1\u5024\u3092\u8003\u3048\u308b\u3068\u3053\u306e\u70b9\u306f\u81f4\u547d\u7684\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002<\/p>\n<p>\u4e00\u5fdc(Tauri\u3092\u9664\u304f)\u5019\u88dc\u3092\u4e71\u96d1\u306b\u6319\u3052\u308b\u3068\u3001\u57fa\u672c\u3068\u306a\u308bwinit\u3092\u59cb\u3081\u3068\u3057\u3066\u3001OpenGL\u306e\u3088\u3046\u306aGPU\u5411\u3051\u306e\u30b0\u30e9\u30d5\u30a3\u30c3\u30afAPI wgpu\u3001GTK\u306e\u30e9\u30c3\u30d1\u30fc\u3068\u3057\u3066\u306egtk-rs\u3001\u305d\u306e\u307b\u304begui\u3084Iced\u7b493\u3001\u69d8\u3005\u306a\u7a2e\u985e\u304c\u5b58\u5728\u3057\u307e\u3059\u304c\u3001C#\u306e.NET core\u306e\u3088\u3046\u306a\u3001\u30ad\u30e9\u30fc\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306f\u306a\u3044\u3068\u3044\u3046\u73fe\u72b6\u3067\u3059\u3002\u6577\u5c45\u306e\u9ad8\u3055\u3082\u76f8\u307e\u3063\u3066\u3001Rust\u3060\u3051\u3067\u306f\u3069\u3046\u3057\u3066\u3082(\u7279\u306bGUI\u5468\u308a\u306e)\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u3084\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u306e\u6210\u9577\u306b\u4e0d\u5b89\u304c\u6b8b\u308a\u307e\u3059\u3002<\/p>\n<p>\u4e00\u65b9TypeScript\u306f\u6570\u5024\u8a08\u7b97\u4ee5\u5916\u3067\u306f\u5e45\u5e83\u3044\u5206\u91ce\u3067\u4f7f\u7528\u304c\u671f\u5f85\u3067\u304d\u305d\u3046\u3067\u3059\u304c\u3001JavaScript\u8b72\u308a\u306e\u4e0d\u5b89\u8981\u7d20\u3084\u4f59\u5270\u6a5f\u80fd\u304c\u3042\u308a\u3001\u5805\u7262\u306a\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u5236\u4f5c\u306b\u5411\u3044\u3066\u3044\u308b\u3068\u81ea\u4fe1\u3092\u6301\u3063\u3066\u8a00\u3046\u306e\u306f\u53b3\u3057\u305d\u3046\u3067\u3059\u3002\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u3057\u3066\u3057\u307e\u3048\u3070\u7d50\u5c40\u306fJS\u3001\u3064\u307e\u308a\u30a4\u30f3\u30bf\u30d7\u30ea\u30bf\u8a00\u8a9e\u3067\u3042\u308b\u3053\u3068\u3082\u3001\u305d\u306e\u4ed6\u306e\u9759\u7684\u578b\u4ed8\u3051\u8a00\u8a9e\u3092\u7f6e\u304d\u63db\u3048\u308b\u307b\u3069\u306e\u8a00\u8a9e\u306b\u306a\u308c\u306a\u3044\u4e00\u56e0\u3067\u3057\u3087\u3046\u3002<\/p>\n<p>\u3057\u304b\u3057\u3001TypeScript\u306b\u306fRust\u306b\u306f\u306a\u3044 \u8a2d\u8a08\u5909\u66f4\u306e\u67d4\u8edf\u3055\u3068\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9(GUI)\u69cb\u7bc9\u306b\u307e\u3064\u308f\u308b\u8c4a\u5bcc\u306a\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u30fb\u30e9\u30a4\u30d6\u30e9\u30ea\u30fb\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u304c\u3042\u308b \u3068\u3044\u3046\u30e1\u30ea\u30c3\u30c8\u304c\u3001\u305d\u3057\u3066Rust\u306b\u306fTypeScript\u306b\u306f\u306a\u3044 \u30b7\u30b9\u30c6\u30e0\u306e\u6839\u5e79\u3092\u81ea\u4fe1\u3092\u3082\u3063\u3066\u4f5c\u308c\u308b\u3001OS\u306eAPI\u3084FFI\u3092\u304c\u3063\u3064\u308a\u89e6\u308c\u308b \u3068\u3044\u3046\u30e1\u30ea\u30c3\u30c8\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u3064\u307e\u308a\u3053\u306e\u300c\u5bfe\u7167\u7684\u306a\u300d2\u4eba\u304c\u4e92\u3044\u306b\u624b\u3092\u53d6\u308a\u5354\u529b\u3057\u305f\u3089\u2026\uff1f\u6700\u5f37\u3067\u697d\u3057\u3044\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u304c\u4f5c\u308c\u308b\u3068\u601d\u3044\u307e\u305b\u3093\u304b\uff1f\u305d\u3093\u306a\u5922\u3092\u53f6\u3048\u3066\u304f\u308c\u308b\u767e\u5408\u4f5c\u54c1\u3082\u3068\u3044\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u304cTauri\u306a\u306e\u3067\u3059\uff01\uff01<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/27-0.png\" alt=\"TS\u00d7Rust\u633f\u7d75\" \/><\/div>\n<p>\u3053\u3053\u307e\u3067\u3075\u3056\u3051\u3066\u8a71\u3057\u307e\u3057\u305f\u304c\u3001\u771f\u9762\u76ee\u306a\u8a71\u3001\u958b\u767a\u52b9\u7387\u3092\u6700\u5927\u306b\u3059\u308b\u306a\u3089Rust\u3068TypeScript\u306b\u3088\u308b\u62c5\u5f53\u5206\u91ce\u5206\u3051\u306b\u306f\u6587\u53e5\u306e\u4ed8\u3051\u3088\u3046\u304c\u3042\u308a\u307e\u305b\u3093\u3002Rust\u3067\u66f8\u3044\u3066\u3044\u308b\u90e8\u5206\u3092TypeScript\u3067\u66f8\u3053\u3046\u3068\u3057\u305f\u3089\u30ea\u30bd\u30fc\u30b9\u7ba1\u7406\u3084\u975e\u540c\u671f\u7b49\u3067\u6c38\u9060\u306b\u6cbc\u308a\u305d\u3046\u3067\u3059\u3057\u3001Rust\u3067\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306b\u76f8\u5f53\u3059\u308b\u90e8\u5206\u3092\u66f8\u304f\u3050\u3089\u3044\u306a\u3089\u8c4a\u5bcc\u306b\u30e9\u30a4\u30d6\u30e9\u30ea\u3084\u60c5\u5831\u304c\u30cd\u30c3\u30c8\u306b\u843d\u3061\u3066\u3044\u308bTypeScript\u3067\u66f8\u3044\u305f\u307b\u3046\u304c\u82e6\u52b4\u3057\u306a\u3044\u3067\u3057\u3087\u3046\u3002<\/p>\n<p>\u300c1\u4eba\u3067\u60a9\u307e\u305a2\u4eba\u3067\u624b\u3092\u53d6\u308a\u5408\u3044\u4e8b\u4ef6\u89e3\u6c7a\u3057\u3066\u3044\u304f\u300d&#8230;\u7d20\u6674\u3089\u3057\u3044\u738b\u9053\u30d1\u30bf\u30fc\u30f3\u3067\u3059\u3002Tauri\u306f\u4eca\u5b63(\u6b21\u4e16\u4ee3\uff1f)\u306e\u8987\u6a29\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306b\u306a\u308b\u529b\u3092\u79d8\u3081\u3066\u3044\u308b\u306e\u3067\u3059\uff01<\/p>\n<h1>\u30a2\u30d7\u30ea\u306e\u89e3\u8aac<\/h1>\n<p>Tauri\u306e\u767e\u5408\u30dd\u30a8\u30e0\u306f\u3053\u306e\u8fba\u306b\u3057\u3066\u3053\u3053\u304b\u3089\u306f\u4eca\u56de\u4f5c\u3063\u305f\u30a2\u30d7\u30ea win-win-map \u306e\u89e3\u8aac\u306b\u5165\u3063\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/32-0.png\" alt=\"winwinmap\u30ad\u30e3\u30d7\u30b7\u30e7\u30f3.png\" \/><\/div>\n<h2>\u5236\u4f5c\u3057\u305f\u52d5\u6a5f<\/h2>\n<p>\u30de\u30a6\u30b9\u30ab\u30fc\u30bd\u30eb\u3084\u30a6\u30a3\u30f3\u30c9\u30a6\u304c\u53ec\u559a\u3067\u304d\u308bwin-win-map\u3067\u3059\u304c\u3001\u6b63\u76f4\u300c\u9762\u767d\u3044\u3060\u3051\u306e\u30aa\u30e2\u30c1\u30e3\u30a2\u30d7\u30ea\u3067\u306f\uff1f\u300d\u3068\u601d\u308f\u308c\u305f\u65b9\u304c\u591a\u3044\u306e\u3067\u306f\u306a\u3044\u3067\u3057\u3087\u3046\u304b\uff1f\u3053\u308c\u306f\u305d\u306e\u901a\u308a\u3067\u3001\u9700\u8981\u304c\u306a\u3055\u305d\u3046\u3060\u3063\u305f\u306e\u3082\u5236\u4f5c\u52d5\u6a5f\u306e\u4e00\u3064\u3060\u3063\u305f\u308a\u3057\u307e\u3059\u3002\u9700\u8981\u304c\u3042\u308c\u3070\u4f55\u304b\u3057\u3089\u65e2\u5b58\u306e\u30a2\u30d7\u30ea\u304c\u5b58\u5728\u3059\u308b\u3082\u306e\u3067\u30595\u3002<\/p>\n<p>\u672c\u5f53\u306e\u52d5\u6a5f\u306f\u7b46\u8005\u306e\u4f5c\u696d\u74b0\u5883\u306b\u3042\u308a\u307e\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/36-0.png\" alt=\"\u30ed\u30d5\u30c8\u30d9\u30c3\u30c9\u74b0\u5883\u56f32.png\" \/><\/div>\n<p>\u7b46\u8005\u306f\u666e\u6bb5\u30ed\u30d5\u30c8\u30d9\u30c3\u30c8\u306e\u673a\u3067\u4f5c\u696d\u3057\u3066\u3044\u307e\u3059\u3002\u3057\u304b\u3057\u3001\u305f\u307e\u306b\u306f\u30d9\u30c3\u30c9\u3067\u5bdd\u306a\u304c\u3089\u4f5c\u696d\u3057\u305f\u3044\u306e\u3067\u3001\u30d9\u30c3\u30c9\u306b\u3082\u30e2\u30cb\u30bf\u3092\u8a2d\u7f6e\u3057\u3066\u3044\u307e\u3059\u3002\u3053\u3061\u3089\u306e\u30e2\u30cb\u30bf\u306b\u306f\u3001\u4e0b\u306e\u968e\u306e\u30e1\u30a4\u30f3\u30e2\u30cb\u30bf\u3092\u30df\u30e9\u30fc\u30ea\u30f3\u30b0\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u30d9\u30c3\u30c9\u3067\u306f\u3001\u5e38\u306b\u5168\u30e2\u30cb\u30bf\u304c\u898b\u3048\u3066\u3044\u308b\u308f\u3051\u3067\u306f\u3042\u308a\u307e\u305b\u3093\u3002\u3053\u3046\u306a\u308b\u3068\u3001\u30d9\u30c3\u30c9\u306b\u884c\u304f\u305f\u3073\u306b\u3001\u4e0b\u306e\u5927\u304d\u3044\u30e2\u30cb\u30bf\u3067\u4f5c\u696d\u3057\u305f\u30a6\u30a3\u30f3\u30c9\u30a6\u3084\u30de\u30a6\u30b9\u30ab\u30fc\u30bd\u30eb\u3092\u968e\u4e0a\u30e2\u30cb\u30bf\u306b\u6301\u3063\u3066\u884c\u304f\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u3053\u306e\u4f5c\u696d\u304c\u624b\u9593\u3060\u3063\u305f\u306e\u304c\u672c\u30a2\u30d7\u30ea\u5236\u4f5c\u306e\u52d5\u6a5f\u3068\u306a\u308a\u307e\u3057\u305f\u3002DIY\u307f\u305f\u3044\u306a\u30ce\u30ea\u3067\u3059\u3002<\/p>\n<h2>win-win-map\u306e\u6a5f\u80fd<\/h2>\n<p>\u6539\u3081\u3066\u6a5f\u80fd\u7d39\u4ecb\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u306b\u3088\u308a\u30de\u30a6\u30b9\u30ab\u30fc\u30bd\u30eb\u3092\u8a2d\u5b9a\u5ea7\u6a19\u306b\u53ec\u559a<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u53ca\u3073\u30dc\u30bf\u30f3\u306b\u3088\u308a\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u8a2d\u5b9a\u5ea7\u6a19\u306b\u53ec\u559a<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u95be\u5024\u5916(\u30d9\u30c3\u30c9\u4e0a\u30e2\u30cb\u30bf\u3058\u3083\u306a\u3044\u9818\u57df)\u306b\u3042\u308b\u30a6\u30a3\u30f3\u30c9\u30a6\u306e\u81ea\u52d5\u53ec\u559a<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u30de\u30c3\u30d7\u4e0a\u30c9\u30e9\u30c3\u30b0\u306b\u3088\u308b\u30a6\u30a3\u30f3\u30c9\u30a6\u79fb\u52d5<\/ul>\n<p>\u504f\u3063\u305f\u6a5f\u80fd\u3057\u304b\u3042\u308a\u307e\u305b\u3093\u304c\u81ea\u5df1\u6e80\u8db3\u30a2\u30d7\u30ea\u306a\u306e\u3067\u3054\u611b\u5b0c\u3002\u8981\u671b\u304c\u3042\u308c\u3070issue\u3092\u4e0b\u3055\u308b\u3068\u5e78\u3044\u3067\u3059\u3002<\/p>\n<p>\u81ea\u5206\u3057\u304b\u4f7f\u308f\u306a\u3044\u305f\u3081\u306b\u8a2d\u5b9a\u9805\u76ee\u3082\u504f\u3063\u3066\u3044\u307e\u3059\u304c\u3001\u30c6\u30ad\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u3092\u7de8\u96c6\u3057\u305f\u308a\u3068\u3044\u3063\u305f\u9762\u5012\u306a\u65b9\u6cd5\u3092\u907f\u3051\u3066\u3044\u307e\u3059\u3002<\/p>\n<h2>win-win-map\u306e\u5927\u307e\u304b\u306a\u69cb\u6210\u30fb\u5236\u4f5c\u624b\u9806<\/h2>\n<p>audio-bookmark\u3068\u540c\u69d8\u306b\u3001Win32API(windows-rs)\u3092\u5229\u7528\u3057\u3066\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u52d5\u304b\u3057\u3066\u3044\u307e\u3059\u3002\u305d\u306e\u305f\u3081\u69cb\u6210\u3082\u4f3c\u901a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/47-0.png\" alt=\"winwinmap\u69cb\u62102.png\" \/><\/div>\n<p>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3067\u4f7f\u7528\u3057\u305f\u6280\u8853\u306e\u8aac\u660e\u306f\u7701\u7565\u3057\u307e\u3059\u3002\u6a5f\u80fd\u7d39\u4ecb\u3092\u66ff\u308f\u308a\u3068\u3055\u305b\u3066\u3044\u305f\u3060\u304d\u307e\u3059\u3002<\/p>\n<p>\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u3067\u4f7f\u7528\u3057\u305fWin32API\u306e\u89e3\u8aac\u306fZenn\u306b\u3066\u5225\u8a18\u4e8b\u306b\u3057\u3066\u307f\u307e\u3057\u305f\u3002\u8208\u5473\u304c\u3042\u308c\u3070\u8aad\u3093\u3067\u3044\u305f\u3060\u3051\u308b\u3068\u5e78\u3044\u3067\u3059\u3002\u2193<\/p>\n<p>&nbsp;<\/p>\n<p>\u5927\u307e\u304b\u306a\u5236\u4f5c\u624b\u9806\u306f\u3001<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>Rust\u5074\u3060\u3051\u3067\u30a6\u30a3\u30f3\u30c9\u30a6\u3084\u30de\u30a6\u30b9\u30ab\u30fc\u30bd\u30eb\u3092\u79fb\u52d5\u3055\u305b\u308bCLI\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u304a\u8a66\u3057\u3067\u4f5c\u308a\u3001API\u3068\u3057\u3066\u76e4\u77f3\u5316\u3059\u308b<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\u30d5\u30ed\u30f3\u30c8\u5074\u304b\u3089Rust\u3067\u4f5c\u3063\u305f\u6a5f\u80fd\u3092\u547c\u3073\u51fa\u3059\u3088\u3046\u306b\u3057\u3066MUI\u3067GUI\u3092\u4f5c\u308b<\/ol>\n<p>\u3068\u3044\u3063\u305f\u611f\u3058\u3067\u3059\u3002Rust\u3067\u304c\u3063\u3061\u308a\u3068\u571f\u53f0\u3092\u4f5c\u3063\u3066\u304b\u3089TypeScript\u3067\u3075\u308f\u3075\u308f\u3057\u305f\u90e8\u5206\u3092\u5b9f\u88c5\u3059\u308b\u624b\u9806\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>Rust\u3060\u3051\u3060\u3068CLI\u6b62\u307e\u308a\u306b\u306a\u3063\u3066\u3057\u307e\u3046\u3088\u3046\u306a\u81ea\u4f5c\u30a2\u30d7\u30ea\u304c\u3001TypeScript\u304c\u4f5c\u308bGUI\u306e\u304a\u304b\u3052\u3067\u4fbf\u5229\u306a\u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\u30c4\u30fc\u30eb\u306b\u4e00\u77ac\u3067\u5316\u3051\u308b\u306e\u3067\u3059\uff01\u3053\u308c\u3053\u305d\u304cTauri\u306b\u3088\u308bDIY\u306e\u918d\u9190\u5473\u3067\u3042\u308a\u3001\u4ed6\u306e\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306b\u306f\u306a\u3044\u5f37\u307f\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u81ea\u5206\u306e\u4e16\u754c\u306b\u7c60\u3063\u3066\u3044\u305fRust\u3092TypeScript\u304c\u5916\u306b\u9023\u308c\u51fa\u3057\u3066\u7121\u53cc\u3059\u308b\u3001Tauri\u306f\u305d\u3093\u306a\u723d\u5feb\u5287\u306a\u3093\u3067\u3059\u3002<\/p>\n<h1>Tauri\u306e\u4fbf\u5229\u6a5f\u80fd\u7d39\u4ecb<\/h1>\n<p>\u7b46\u8005\u3068\u3057\u3066\u306e\u30e1\u30a4\u30f3\u30b3\u30f3\u30c6\u30f3\u30c4\u306f\u3053\u3053\u307e\u3067\u3067\u7d42\u308f\u308a\u3067\u3059\u304c\u3001\u8aad\u8005\u306b\u3068\u3063\u3066\u306f\u3053\u3053\u304b\u3089\u304c\u30e1\u30a4\u30f3\u3067\u3057\u3087\u3046() \u3068\u3044\u3046\u308f\u3051\u3067\u3001\u30aa\u30b9\u30b9\u30e1\u6a5f\u80fd\u7d39\u4ecb\u3067\u3059\u3002<\/p>\n<p>\u672c\u7bc0\u3067\u306f\u3001\u3044\u304f\u3064\u304bTauri\u30a2\u30d7\u30ea\u3092\u4f5c\u3063\u3066\u304d\u305f\u4e2d\u3067\u300cTauri\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306e\u3053\u3053\u304c\u3059\u3054\u3044\uff01Tauri\u9b42\uff01\u300d\u3068\u306a\u3063\u305f\u8981\u7d20\u3092\u5099\u5fd8\u9332\u3068\u3057\u3066\u30d4\u30c3\u30af\u30a2\u30c3\u30d7\u3057\u307e\u3057\u305f\u3002\u300cTauri\u3092\u4f7f\u3048\u3070\u3053\u3093\u306a\u3053\u3068\u3082\u5b9f\u73fe\u3067\u304d\u308b\u306e\u304b\uff5e\u300d\u307f\u305f\u3044\u306a\u96f0\u56f2\u6c17\u3067\u8aad\u3093\u3067\u3044\u305f\u3060\u3051\u308b\u3068\u5e78\u3044\u3067\u3059\u3002<\/p>\n<p>\u306a\u304a\u6c17\u5206\u3068\u3057\u3066\u306f\u5192\u982d\u3067\u6319\u3052\u305f\u30cf\u30f3\u30ba\u30aa\u30f3\u8a18\u4e8b\u306e\u7d9a\u304d\u3068\u3057\u3066\u66f8\u3044\u3066\u3044\u308b\u306e\u3067\u3001\u3053\u3053\u307e\u3067\u3092\u8aad\u3093\u3067Tauri\u306b\u89e6\u308c\u305f\u304f\u306a\u3063\u305f\u65b9\u306f\u30cf\u30f3\u30ba\u30aa\u30f3\u306e\u65b9\u306b\u3082\u76ee\u3092\u901a\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u30cf\u30f3\u30ba\u30aa\u30f3\u3067\u306fWindows\u3067\u958b\u767a\u3092\u884c\u3063\u3066\u3044\u305f\u305f\u3081\u3001\u672c\u8a18\u4e8b\u3067\u7d39\u4ecb\u3059\u308b\u6a5f\u80fd\u3082\u5168\u3066Windows\u3092\u524d\u63d0\u3068\u3057\u3066\u691c\u8a3c\u3057\u8a18\u8ff0\u3057\u3066\u3044\u307e\u3059\u3002\u691c\u8a3c\u306b\u95a2\u308f\u308b\u5404\u30a2\u30d7\u30ea\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u306f\u4ee5\u4e0b\u306e\u901a\u308a\u3067\u3059\u3002\u6f0f\u308c\u304c\u3042\u308c\u3070\u30b3\u30e1\u30f3\u30c8\u3067\u5c0b\u306d\u3066\u3044\u305f\u3060\u3051\u308b\u3068\u5e78\u3044\u3067\u3059\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">tauri: 1.2<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">cargo: 1.66.0<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">yarn: 1.22.19<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">tauri-cli: 1.2.3<\/ul>\n<details>\u30d0\u30fc\u30b8\u30e7\u30f3\u78ba\u8a8d\u8a73\u7d30PowerShell<br \/>\n&gt; rustup &#8211;version<br \/>\nrustup 1.25.1 (bb60b1e89 2022-07-12)<br \/>\ninfo: This is the version for the rustup toolchain manager, not the rustc compiler.<br \/>\ninfo: The currently active `rustc` version is `rustc 1.66.0 (69f9c33d7 2022-12-12)`<br \/>\n&gt; cargo &#8211;version<br \/>\ncargo 1.66.0 (d65d197ad 2022-11-15)<br \/>\n&gt; node -v<br \/>\nv18.4.0<br \/>\n&gt; npm -v<br \/>\n8.13.1<br \/>\n&gt; yarn -v<br \/>\n1.22.19<br \/>\n&gt; cd tauri-project<br \/>\n&gt; yarn tauri &#8211;version<br \/>\nyarn run v1.22.19<br \/>\n$ tauri &#8211;version<br \/>\ntauri-cli 1.2.3<br \/>\nDone in 0.15s.<\/p>\n<p>Cargo.toml(\u4e00\u90e8\u629c\u7c8b)<br \/>\n[dependencies]<br \/>\ntauri = { version = &#8220;1.2&#8221;, features = [&#8220;path-all&#8221;, &#8220;protocol-asset&#8221;, &#8220;window-all&#8221;] }<br \/>\nserde = { version = &#8220;1.0&#8221;, features = [&#8220;derive&#8221;] }<br \/>\nserde_json = &#8220;1.0&#8221;<\/p>\n<p>tauri\u306efeatures\u306ftauri.conf.json\u306b\u4f9d\u5b58\u3057\u3066\u81ea\u52d5\u3067\u66f8\u304d\u63db\u308f\u308b\u306e\u3067\u6c17\u306b\u3057\u306a\u3044\u3067\u304f\u3060\u3055\u3044\u3002<\/p>\n<\/details>\n<p>\u307e\u3068\u3081\u3068\u3044\u3046\u3053\u3068\u3067\u30cf\u30f3\u30ba\u30aa\u30f3\u3067\u7d39\u4ecb\u3057\u305f\u5185\u5bb9\u3082\u6539\u3081\u3066\u7c21\u5358\u306b\u7d39\u4ecb\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<div>\n<p>\u4f8b\u3068\u3057\u3066\u6319\u3052\u3066\u3044\u308b\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u306f\u898b\u3084\u3059\u3055\u3092\u512a\u5148\u3057\u305f\u4e0d\u5b8c\u5168\u306a\u3082\u306e\u3067\u3059\u3002\u9069\u5b9c\u30cf\u30f3\u30ba\u30aa\u30f3\u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u7b49\u3092\u53c2\u7167\u3057\u3066\u304f\u3060\u3055\u3044\u3002<br \/>\n\u307e\u305f\u4f8b\u3067\u306funwrap\u3092\u591a\u7528\u3057\u3066\u3044\u307e\u3059\u304c\u5b9f\u969b\u306b\u30a2\u30d7\u30ea\u3092\u4f5c\u308b\u6642\u306f\u9069\u5207\u306a\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3092\u5fc3\u304c\u3051\u307e\u3057\u3087\u3046\u3002<\/p>\n<\/div>\n<p>\u76ee\u6b216<\/p>\n<p>\u30d0\u30c3\u30af\u30a8\u30f3\u30c9(Rust)\u7de8<\/p>\n<p>\u30b3\u30de\u30f3\u30c9\u3068\u30de\u30af\u30ed\u306e\u6a5f\u80fd\u5b9a\u7fa9<br \/>\nserde\u3068\u30c7\u30fc\u30bf\u306e\u69cb\u9020\u5b9a\u7fa9<br \/>\n\u30e1\u30cb\u30e5\u30fc\u3068\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u306eUI\u62e1\u5f35<br \/>\n\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3068\u30a4\u30d9\u30f3\u30c8\u7d4c\u7531\u306e\u76f8\u4e92\u4f5c\u7528<\/p>\n<p>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9(TypeScript)\u7de8<\/p>\n<p>\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3068fs\u306e\u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58<br \/>\n\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u3068\u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9\u306e\u6a5f\u80fd\u5b9f\u884c<br \/>\n\u30e6\u30fc\u30b6\u30fc\u3068OS\u306e\u30a2\u30d7\u30ea\u901a\u77e5<\/p>\n<p>Tauri\u7de8<\/p>\n<p>CLI\u3068\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u306e\u5f15\u6570\u6307\u5b9a<br \/>\n\u30d7\u30e9\u30b0\u30a4\u30f3\u3068\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u81ea\u52d5\u59cb\u52d5<br \/>\n\u6a5f\u80fd\u5206\u5272\u3068URL\u6307\u5b9a\u306e\u30de\u30eb\u30c1\u30a6\u30a3\u30f3\u30c9\u30a6<br \/>\n\u30a2\u30a4\u30b3\u30f3\u751f\u6210\u3068\u81ea\u52d5\u53cd\u6620\u306e\u753b\u7adc\u70b9\u775b<br \/>\n\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u3068GitHubActions\u306e\u30c7\u30d7\u30ed\u30a4\u9769\u547d<\/p>\n<h2>\u30d0\u30c3\u30af\u30a8\u30f3\u30c9(Rust)\u7de8<\/h2>\n<h3>\u30b3\u30de\u30f3\u30c9\u3068\u30de\u30af\u30ed\u306e\u6a5f\u80fd\u5b9a\u7fa9<\/h3>\n<p>Rust\u5074\u306e\u95a2\u6570\u306b#[tauri::command]\u3068\u3044\u3046\u5c5e\u6027\u98a8\u30de\u30af\u30ed\u3092\u3064\u3051\u3001invoke_handler\u306b\u767b\u9332\u3059\u308b\u3068\u3001TypeScript\u5074\u304b\u3089invoke\u95a2\u6570\u3067\u547c\u3073\u51fa\u305b\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002Tauri\u306e\u6700\u3082\u57fa\u672c\u3068\u306a\u308b\u6a5f\u80fd\u3067\u3059\u3002<\/p>\n<p>\u30de\u30af\u30ed\u3092\u3064\u3051\u308b\u95a2\u6570\u306f\u540c\u671f\u95a2\u6570\u3067\u3082\u975e\u540c\u671f\u95a2\u6570\u3067\u3082\u3069\u3061\u3089\u3067\u3082\u69cb\u3044\u307e\u305b\u3093\u3002\u4f8b\u3067\u306f\u540c\u671f\u95a2\u6570\u306b\u3064\u3051\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ \u95a2\u6570\u306b\u5c5e\u6027\u98a8\u30de\u30af\u30ed\u3092\u3064\u3051\u308b<\/span>\r\n<span class=\"nd\">#[tauri::command]<\/span>\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">get_entries<\/span><span class=\"p\">(<\/span><span class=\"n\">path<\/span><span class=\"p\">:<\/span> <span class=\"o\">&amp;<\/span><span class=\"nb\">str<\/span><span class=\"p\">)<\/span> <span class=\"k\">-&gt;<\/span> <span class=\"nb\">Result<\/span><span class=\"o\">&lt;<\/span><span class=\"nb\">Vec<\/span><span class=\"o\">&lt;<\/span><span class=\"n\">Entry<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">,<\/span> <span class=\"nb\">String<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">res<\/span> <span class=\"o\">=<\/span> <span class=\"cm\">\/* omit details. return Vec&lt;Entry&gt; value *\/<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"nf\">Ok<\/span><span class=\"p\">(<\/span><span class=\"n\">res<\/span><span class=\"p\">)<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n\r\n        <span class=\"c1\">\/\/ invoke_handler\u3067\u767b\u9332\u3059\u308b<\/span>\r\n        <span class=\"nf\">.invoke_handler<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_handler!<\/span><span class=\"p\">[<\/span><span class=\"n\">get_entries<\/span><span class=\"p\">])<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">App<\/span> <span class=\"o\">=<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">dir<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setDir<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useState<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">string<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">null<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"kc\">null<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">entries<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setEntries<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useState<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">Entries<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">null<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"kc\">null<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"p\">(<\/span><span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n\r\n      <span class=\"kd\">const<\/span> <span class=\"nx\">entries<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nx\">invoke<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">Entries<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">get_entries<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span> <span class=\"na\">path<\/span><span class=\"p\">:<\/span> <span class=\"nx\">dir<\/span> <span class=\"p\">})<\/span>\r\n        <span class=\"p\">.<\/span><span class=\"k\">catch<\/span><span class=\"p\">(<\/span><span class=\"nx\">err<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n          <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nf\">error<\/span><span class=\"p\">(<\/span><span class=\"nx\">err<\/span><span class=\"p\">);<\/span>\r\n          <span class=\"k\">return<\/span> <span class=\"kc\">null<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"p\">});<\/span>\r\n\r\n      <span class=\"nf\">setEntries<\/span><span class=\"p\">(<\/span><span class=\"nx\">entries<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"p\">})();<\/span>\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[<\/span><span class=\"nx\">dir<\/span><span class=\"p\">]);<\/span>\r\n\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">App<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<p>invoke\u306e\u7b2c\u4e00\u5f15\u6570\u306b\u547c\u3073\u51fa\u3057\u305f\u3044\u95a2\u6570\u540d\u3001\u7b2c\u4e8c\u5f15\u6570\u306b\u305d\u306e\u95a2\u6570\u306e\u5f15\u6570\u3092\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3067\u6307\u5b9a\u3057\u3066\u547c\u3073\u51fa\u3057\u307e\u3059\u3002<\/p>\n<p>invoke\u306fRust\u95a2\u6570\u306b\u95a2\u4fc2\u306a\u304f\u975e\u540c\u671f\u95a2\u6570\u3067\u3042\u308b\u305f\u3081\u3001\u4f8b\u3048\u3070React\u306e\u5834\u5408\u306f\u4f8b\u306b\u793a\u3057\u305f\u3088\u3046\u306buseEffect\u5185\u3067\u975e\u540c\u671f\u95a2\u6570\u306b\u5305\u3093\u3067\u547c\u3073\u51fa\u3059\u7b49\u304c\u4e3b\u306a\u4f7f\u3044\u65b9\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<div>\n<p>React\u306e\u5834\u5408\u3001useEffect\u306f\u30c7\u30d0\u30c3\u30b0\u6642\u306b\u4e8c\u5ea6\u8d70\u308b\u3053\u3068\u306b\u6c17\u3092\u3064\u3051\u307e\u3057\u3087\u3046\u3002(\u53c2\u8003: useEffect\u304c\u30de\u30a6\u30f3\u30c8\u6642\u306b2\u56de\u5b9f\u884c\u3055\u308c\u308b &#8211; Qiita )<br \/>\n\u3082\u3057Rust\u95a2\u6570\u3092\u4e00\u5ea6\u3057\u304b\u547c\u3073\u51fa\u3057\u3066\u307b\u3057\u304f\u306a\u3044\u5834\u5408\u3001useRef\u3092\u4f7f\u3046\u306a\u3069\u3067\u5bfe\u7b56\u3067\u304d\u307e\u3059\u3002<br \/>\n2023\/07\/19 \u8ffd\u8a18<br \/>\ninvoke \u306f useEffect \u3092\u4f7f\u3046\u306e\u306f\u9069\u3055\u306a\u3044\u30b1\u30fc\u30b9\u304c\u591a\u3044(get_entries\u306f\u3081\u305a\u3089\u3057\u304f\u9069\u5207\u306a\u30b1\u30fc\u30b9)\u3067\u3059\u3002\u4e8c\u56de\u5b9f\u884c\u3055\u308c\u3066\u56f0\u308b\u3088\u3046\u306a\u51e6\u7406\u306a\u3089\u3070\u3001\u53ef\u80fd\u306a\u9650\u308a\u30e6\u30fc\u30b6\u30fc\u30a2\u30af\u30b7\u30e7\u30f3\u306b\u7d50\u3073\u3064\u3044\u305f\u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9\u306b\u66f8\u304d\u307e\u3057\u3087\u3046(useRef \u306f\u6700\u7d42\u624b\u6bb5\u3067\u3059)\u3002<br \/>\n\u53c2\u8003\u306b\u3069\u3046\u305e: \u300cReact\u3067await\u3057\u305f\u3089\u58ca\u308c\u305f\u300d\u300cReact\u3067await\u3057\u305f\u3089\u58ca\u308c\u305f\u300d \uff5e useEffect\u306e\u8aa4\u7528\u30682\u56de\u5b9f\u884c \uff5e &#8211; Qiita<br \/>\n\u4ee5\u964d\u672c\u8a18\u4e8b\u3067\u3082 useEffect \u3092\u591a\u7528\u3057\u3066\u3044\u307e\u3059\u304c\u57f7\u7b46\u5f53\u6642\u7b46\u8005\u304c\u2191\u3092\u77e5\u3089\u306a\u304b\u3063\u305f\u305f\u3081\u3067\u3059\u3002\u3054\u4e86\u627f\u304f\u3060\u3055\u3044\u3002<\/p>\n<\/div>\n<p>\u306a\u304a\u30b3\u30de\u30f3\u30c9\u306e\u5f15\u6570\u3068\u3057\u3066\u3001TypeScript\u5074\u3067\u6307\u5b9a\u3059\u308b\u3082\u306e\u306e\u4ed6\u3001\u95a2\u6570\u3092\u547c\u3073\u51fa\u3057\u305f\u30a6\u30a3\u30f3\u30c9\u30a6\u3084\u3001\u30a2\u30d7\u30ea\u306eAppHandle\u3001\u30a2\u30d7\u30ea\u304c\u30e1\u30a4\u30f3\u30eb\u30fc\u30d7\u3067\u6240\u6709\u3057\u3066\u3044\u308b\u30ea\u30bd\u30fc\u30b9\u7b49\u3092\u6e21\u3059\u3053\u3068\u3082\u53ef\u80fd\u3067\u3059\u3002<\/p>\n<p>\u4ee5\u4e0b\u306f\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u5074\u3067\u72b6\u614b\u7ba1\u7406\u3057\u3066\u3044\u308b\u4f8b\u3067\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"k\">use<\/span> <span class=\"nn\">std<\/span><span class=\"p\">::<\/span><span class=\"nn\">sync<\/span><span class=\"p\">::<\/span><span class=\"n\">Mutex<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"nd\">#[tauri::command]<\/span>\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">get_state<\/span><span class=\"p\">(<\/span><span class=\"n\">state<\/span><span class=\"p\">:<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"n\">State<\/span><span class=\"o\">&lt;<\/span><span class=\"nv\">'_<\/span><span class=\"p\">,<\/span> <span class=\"n\">Mutex<\/span><span class=\"o\">&lt;<\/span><span class=\"nb\">bool<\/span><span class=\"o\">&gt;&gt;<\/span><span class=\"p\">)<\/span> <span class=\"k\">-&gt;<\/span> <span class=\"nb\">bool<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">state<\/span> <span class=\"o\">=<\/span> <span class=\"n\">state<\/span><span class=\"nf\">.lock<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"o\">*<\/span><span class=\"n\">state<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"nd\">#[tauri::command]<\/span>\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">toggle_state<\/span><span class=\"p\">(<\/span><span class=\"n\">state<\/span><span class=\"p\">:<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"n\">State<\/span><span class=\"o\">&lt;<\/span><span class=\"nv\">'_<\/span><span class=\"p\">,<\/span> <span class=\"n\">Mutex<\/span><span class=\"o\">&lt;<\/span><span class=\"nb\">bool<\/span><span class=\"o\">&gt;&gt;<\/span><span class=\"p\">)<\/span> <span class=\"k\">-&gt;<\/span> <span class=\"nb\">bool<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"k\">mut<\/span> <span class=\"n\">state<\/span> <span class=\"o\">=<\/span> <span class=\"n\">state<\/span><span class=\"nf\">.lock<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"o\">*<\/span><span class=\"n\">state<\/span> <span class=\"o\">=<\/span> <span class=\"o\">!*<\/span><span class=\"n\">state<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"o\">*<\/span><span class=\"n\">state<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">state<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">Mutex<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"k\">false<\/span><span class=\"p\">);<\/span>\r\n\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.invoke_handler<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_handler!<\/span><span class=\"p\">[<\/span><span class=\"n\">get_entries<\/span><span class=\"p\">,<\/span> <span class=\"n\">toggle_state<\/span><span class=\"p\">,<\/span> <span class=\"n\">get_state<\/span><span class=\"p\">])<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u30ea\u30bd\u30fc\u30b9\u767b\u9332<\/span>\r\n        <span class=\"nf\">.manage<\/span><span class=\"p\">(<\/span><span class=\"n\">state<\/span><span class=\"p\">)<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>State\u81ea\u4f53\u304cDeref\u3092\u5b9f\u88c5\u3057\u3066\u3044\u308b\u306e\u3067Arc\u306f\u4e0d\u8981\u3067\u3059\u3002\u4f8b\u3067\u306f\u53ef\u5909\u6027\u3092\u6301\u305f\u305b\u305f\u3044\u306e\u3067Mutex\u3067\u5305\u3093\u3067\u3044\u307e\u3059\u3002<\/p>\n<details>\u30d5\u30ed\u30f3\u30c8\u5074TypeScript<br \/>\nimport { useEffect, useState } from &#8216;react&#8217;;<br \/>\nimport { invoke } from &#8216;@tauri-apps\/api&#8217;;<\/p>\n<p>const App = () =&gt; {<br \/>\nconst [state, setState] = useState(false);<\/p>\n<p>useEffect(() =&gt; {<br \/>\n(async () =&gt; {<br \/>\nconst s = await invoke(&#8220;get_state&#8221;);<br \/>\nsetState(s);<br \/>\n})();<br \/>\n}, []);<\/p>\n<p>return (<br \/>\n&lt;&gt;<\/p>\n<div>state: {state ? &#8220;on&#8221; : &#8220;off&#8221;}<\/div>\n<p><button> invoke(&#8220;toggle_state&#8221;).then((s: boolean) =&gt; setState(s))}&gt;toggle<\/button><br \/>\n&lt;\/&gt;<br \/>\n);<br \/>\n}<\/p>\n<p>export default App;<\/p>\n<\/details>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Calling Rust from the frontend | Tauri Apps<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Accessing the Window in Commands<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Accessing Managed State<\/ul>\n<h3>serde\u3068\u30c7\u30fc\u30bf\u306e\u69cb\u9020\u5b9a\u7fa9<\/h3>\n<p>\u524d\u9805\u76ee\u306e\u95a2\u6570\u547c\u3073\u51fa\u3057\u306b\u304a\u3044\u3066\u3001Rust\u95a2\u6570\u3092TypeScript\u3067\u6271\u3046\u306b\u306f\u5f15\u6570\u3082\u8fd4\u308a\u5024\u3082Rust\u3068TypeScript\u306e\u4e21\u65b9\u3067\u6271\u3048\u308b\u578b\u3067\u3042\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u300c\u4e21\u65b9\u3067\u6271\u3048\u308b\u578b\u300d\u306f\u3001\u300cJSON\u3067\u4f7f\u3048\u308b\u578b\u300d\u3068\u8003\u3048\u3066\u5dee\u652f\u3048\u3042\u308a\u307e\u305b\u3093\u3002\u305d\u306e\u305f\u3081\u6587\u5b57\u5217\u578b\u3084\u6570\u5024\u578b\u306f\u7279\u306b\u4f55\u3082\u305b\u305a\u3068\u3082\u5f15\u6570\u3001\u8fd4\u308a\u5024\u306e\u578b\u3068\u3057\u3066\u6307\u5b9a\u3067\u304d\u307e\u3059\u3002(\u306a\u304a\u8fd4\u308a\u5024\u3067Result\u578b\u3092\u8fd4\u3059\u3088\u3046\u306b\u3059\u308b\u3068\u3001Err\u306e\u6642\u306fcatch\u30e1\u30bd\u30c3\u30c9\u304c\u5b9f\u884c\u3055\u308c\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002)<\/p>\n<p>\u30e6\u30fc\u30b6\u30fc\u304c\u5b9a\u7fa9\u3057\u305f\u578b(\u69cb\u9020\u4f53\u3084\u5217\u6319\u4f53)\u306e\u5834\u5408\u3001Rust\u5074\u3067serde\u306e\u30c8\u30ec\u30a4\u30c8\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u6271\u3048\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002\u5f15\u6570\u306b\u4f7f\u3044\u305f\u3044\u578b\u306b\u306fserde::Deserialize\u3001\u8fd4\u308a\u5024\u306b\u4f7f\u3044\u305f\u3044\u578b\u306b\u306fserde::Serialize\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n<p>\u4ee5\u4e0b\u306f\u8fd4\u308a\u5024\u7528\u306e\u578b\u3092\u5b9a\u7fa9\u3059\u308b\u4f8b\u3067\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nd\">#[derive(serde::Serialize)]<\/span>\r\n<span class=\"nd\">#[serde(tag<\/span> <span class=\"nd\">=<\/span> <span class=\"s\">\"type\"<\/span><span class=\"nd\">)]<\/span>\r\n<span class=\"k\">enum<\/span> <span class=\"n\">Entry<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nd\">#[serde(rename<\/span> <span class=\"nd\">=<\/span> <span class=\"s\">\"file\"<\/span><span class=\"nd\">)]<\/span>\r\n    <span class=\"n\">File<\/span> <span class=\"p\">{<\/span> <span class=\"n\">name<\/span><span class=\"p\">:<\/span> <span class=\"nb\">String<\/span><span class=\"p\">,<\/span> <span class=\"n\">path<\/span><span class=\"p\">:<\/span> <span class=\"nb\">String<\/span> <span class=\"p\">},<\/span>\r\n    <span class=\"nd\">#[serde(rename<\/span> <span class=\"nd\">=<\/span> <span class=\"s\">\"dir\"<\/span><span class=\"nd\">)]<\/span>\r\n    <span class=\"n\">Dir<\/span> <span class=\"p\">{<\/span> <span class=\"n\">name<\/span><span class=\"p\">:<\/span> <span class=\"nb\">String<\/span><span class=\"p\">,<\/span> <span class=\"n\">path<\/span><span class=\"p\">:<\/span> <span class=\"nb\">String<\/span> <span class=\"p\">},<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\">\/\/ Entry\u306bSerialize\u304c\u5b9f\u88c5\u3055\u308c\u308b\u3068\u3001Vec&lt;Entry&gt;\u306b\u3082Serialize\u304c\u81ea\u52d5\u5b9f\u88c5\u3055\u308c\u308b<\/span>\r\n\r\n<span class=\"cm\">\/* \u4f8b\r\nFile {\r\n    name: \"memo.txt\",\r\n    path: \"C:\/Users\/namnium\/Desktop\/memo.txt\"\r\n}\r\n\r\nDir {\r\n    name: \"Desktop\",\r\n    path: \"C:\/Users\/namnium\/Desktop\"\r\n}\r\n*\/<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"type\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"file\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"name\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"memo.txt\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"path\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"C:\/Users\/namnium\/Desktop\/memo.txt\"<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"type\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"dir\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"name\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"Desktop\"<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"nl\">\"path\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"C:\/Users\/namnium\/Desktop\"<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"kd\">type<\/span> <span class=\"nx\">Entry<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"na\">type<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">dir<\/span><span class=\"dl\">'<\/span> <span class=\"o\">|<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">file<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">name<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">path<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">};<\/span>\r\n\r\n<span class=\"kd\">type<\/span> <span class=\"nx\">Entries<\/span> <span class=\"o\">=<\/span> <span class=\"nb\">Array<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">Entry<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<p>Rust\u306fEnum\u3067\u3001TypeScript\u306f\u30e6\u30cb\u30aa\u30f3\u578b\u3067\u3068\u3001\u305d\u308c\u305e\u308c\u306e\u66f8\u304d\u3084\u3059\u3044\u65b9\u6cd5\u3067\u578b\u3092\u6271\u3048\u3066\u3044\u308b\u70b9\u304c\u826f\u3044\u3067\u3059\u3002\u307e\u308b\u3067Rust\u3068TypeScript\u304c\u578b\u3092\u901a\u3058\u3066\u4f1a\u8a71\u3057\u3066\u3044\u308b\u3088\u3046\u3067\u3059 (\u91cd\u75c7)<\/p>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Passing Arguments<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Returning Data<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Rust\u306eSerde\u306e\u7c21\u5358\u306a\u7d39\u4ecb &#8211; Qiita<\/ul>\n<h3>\u30e1\u30cb\u30e5\u30fc\u3068\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u306eUI\u62e1\u5f35<\/h3>\n<p>Tauri\u88fd\u30bd\u30d5\u30c8\u304c\u305f\u3060WebView\u306b\u4f55\u304b\u3092\u8868\u793a\u3059\u308b\u3060\u3051\u306e\u30a2\u30d7\u30ea\u3060\u3063\u305f\u3089\u3053\u3053\u307e\u3067\u71b1\u4e2d\u3057\u3066\u3044\u306a\u304b\u3063\u305f\u304b\u3082\u3057\u308c\u306a\u3044&#8230;\u305d\u3046\u601d\u308f\u305b\u308b\u6a5f\u80fd\u304c\u300c\u30a6\u30a3\u30f3\u30c9\u30a6\u30e1\u30cb\u30e5\u30fc\u300d\u3068\u300c\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u300d\u306b\u306a\u308a\u307e\u3059\u3002\u3069\u3046\u3044\u3046\u6a5f\u80fd\u304b\u306f\u305d\u308c\u305e\u308c\u306e\u753b\u50cf\u3092\u898b\u3066\u3044\u305f\u3060\u3051\u308c\u3070\u308f\u304b\u308b\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u30a6\u30a3\u30f3\u30c9\u30a6\u30e1\u30cb\u30e5\u30fc\u30fb\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u3068\u3082\u306b\u3001\u30d3\u30eb\u30c9\u30e1\u30bd\u30c3\u30c9\u306b\u304a\u3044\u3066\u3001\u9805\u76ee\u3068\u9805\u76ee\u304c\u62bc\u3055\u308c\u305f\u6642\u7528\u306e\u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9\u3092\u8a2d\u5b9a\u3059\u308b\u3053\u3068\u3067\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n<p>\u30a6\u30a3\u30f3\u30c9\u30a6\u30e1\u30cb\u30e5\u30fc\u306e\u4f8b<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/99-0.png\" alt=\"image.png\" \/><\/div>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"k\">use<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::{<\/span><span class=\"n\">CustomMenuItem<\/span><span class=\"p\">,<\/span> <span class=\"n\">Menu<\/span><span class=\"p\">,<\/span> <span class=\"n\">WindowMenuEvent<\/span><span class=\"p\">,<\/span> <span class=\"n\">Submenu<\/span><span class=\"p\">,<\/span> <span class=\"n\">Wry<\/span><span class=\"p\">};<\/span>\r\n\r\n<span class=\"c1\">\/\/ \u9805\u76ee\u306e\u8a2d\u5b9a<\/span>\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">create_menu<\/span><span class=\"p\">()<\/span> <span class=\"k\">-&gt;<\/span> <span class=\"n\">Menu<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">quit<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">CustomMenuItem<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"s\">\"quit\"<\/span><span class=\"nf\">.to_string<\/span><span class=\"p\">(),<\/span> <span class=\"s\">\"Quit\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">close<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">CustomMenuItem<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"s\">\"close\"<\/span><span class=\"nf\">.to_string<\/span><span class=\"p\">(),<\/span> <span class=\"s\">\"Close\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">submenu<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">Submenu<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"s\">\"File\"<\/span><span class=\"p\">,<\/span> <span class=\"nn\">Menu<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">()<\/span><span class=\"nf\">.add_item<\/span><span class=\"p\">(<\/span><span class=\"n\">quit<\/span><span class=\"p\">)<\/span><span class=\"nf\">.add_item<\/span><span class=\"p\">(<\/span><span class=\"n\">close<\/span><span class=\"p\">));<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">menu<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">Menu<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.add_item<\/span><span class=\"p\">(<\/span><span class=\"nn\">CustomMenuItem<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"s\">\"hide\"<\/span><span class=\"p\">,<\/span> <span class=\"s\">\"Hide\"<\/span><span class=\"p\">))<\/span>\r\n        <span class=\"nf\">.add_submenu<\/span><span class=\"p\">(<\/span><span class=\"n\">submenu<\/span><span class=\"p\">);<\/span>\r\n\r\n    <span class=\"n\">menu<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"c1\">\/\/ \u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9<\/span>\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">on_main_menu_event<\/span><span class=\"p\">(<\/span><span class=\"n\">event<\/span><span class=\"p\">:<\/span> <span class=\"n\">WindowMenuEvent<\/span><span class=\"o\">&lt;<\/span><span class=\"n\">Wry<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">match<\/span> <span class=\"n\">event<\/span><span class=\"nf\">.menu_item_id<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"s\">\"hide\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"n\">event<\/span><span class=\"nf\">.window<\/span><span class=\"p\">()<\/span><span class=\"nf\">.hide<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">(),<\/span>\r\n        <span class=\"s\">\"quit\"<\/span> <span class=\"p\">|<\/span> <span class=\"s\">\"close\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"n\">event<\/span><span class=\"nf\">.window<\/span><span class=\"p\">()<\/span><span class=\"nf\">.close<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">(),<\/span>\r\n        <span class=\"n\">_<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"p\">{}<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.invoke_handler<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_handler!<\/span><span class=\"p\">[<\/span><span class=\"n\">get_entries<\/span><span class=\"p\">])<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u767b\u9332<\/span>\r\n        <span class=\"nf\">.menu<\/span><span class=\"p\">(<\/span><span class=\"nf\">create_menu<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.on_menu_event<\/span><span class=\"p\">(<\/span><span class=\"n\">on_main_menu_event<\/span><span class=\"p\">)<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u306e\u4f8b<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/102-0.png\" alt=\"image.png\" \/><\/div>\n<p>\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u306e\u5834\u5408\u306ftauri.conf.json\u306b\u3082\u5c11\u3057\u8ffd\u8a18\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"nl\">\"tauri\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n    <span class=\"nl\">\"systemTray\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nl\">\"iconPath\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"icons\/icon.png\"<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"nl\">\"iconAsTemplate\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span>\r\n    <span class=\"p\">}<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>Rust\u5074\u306e\u8a18\u8ff0\u306f\u30a6\u30a3\u30f3\u30c9\u30a6\u30e1\u30cb\u30e5\u30fc\u306e\u5834\u5408\u306b\u4f3c\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"k\">use<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::{<\/span><span class=\"n\">Manager<\/span><span class=\"p\">,<\/span> <span class=\"n\">AppHandle<\/span><span class=\"p\">,<\/span> <span class=\"n\">Wry<\/span><span class=\"p\">};<\/span>\r\n<span class=\"k\">use<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::{<\/span><span class=\"n\">SystemTray<\/span><span class=\"p\">,<\/span> <span class=\"n\">CustomMenuItem<\/span><span class=\"p\">,<\/span> <span class=\"n\">SystemTrayMenu<\/span><span class=\"p\">,<\/span> <span class=\"n\">SystemTrayMenuItem<\/span><span class=\"p\">,<\/span> <span class=\"n\">SystemTrayEvent<\/span><span class=\"p\">};<\/span>\r\n\r\n<span class=\"c1\">\/\/ \u9805\u76ee\u306e\u8a2d\u5b9a<\/span>\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">create_systemtray<\/span><span class=\"p\">()<\/span> <span class=\"k\">-&gt;<\/span> <span class=\"n\">SystemTray<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">hide<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">CustomMenuItem<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"s\">\"hide\"<\/span><span class=\"nf\">.to_string<\/span><span class=\"p\">(),<\/span> <span class=\"s\">\"Hide\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">show<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">CustomMenuItem<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"s\">\"show\"<\/span><span class=\"nf\">.to_string<\/span><span class=\"p\">(),<\/span> <span class=\"s\">\"Show\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">quit<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">CustomMenuItem<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"s\">\"quit\"<\/span><span class=\"nf\">.to_string<\/span><span class=\"p\">(),<\/span> <span class=\"s\">\"Quit\"<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">tray_menu<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">SystemTrayMenu<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.add_item<\/span><span class=\"p\">(<\/span><span class=\"n\">hide<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"nf\">.add_item<\/span><span class=\"p\">(<\/span><span class=\"n\">show<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"nf\">.add_native_item<\/span><span class=\"p\">(<\/span><span class=\"nn\">SystemTrayMenuItem<\/span><span class=\"p\">::<\/span><span class=\"n\">Separator<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"nf\">.add_item<\/span><span class=\"p\">(<\/span><span class=\"n\">quit<\/span><span class=\"p\">);<\/span>\r\n\r\n    <span class=\"k\">let<\/span> <span class=\"n\">tray<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">SystemTray<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">()<\/span><span class=\"nf\">.with_menu<\/span><span class=\"p\">(<\/span><span class=\"n\">tray_menu<\/span><span class=\"p\">);<\/span>\r\n\r\n    <span class=\"n\">tray<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n\r\n<span class=\"c1\">\/\/ \u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9<\/span>\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">on_system_tray_event<\/span><span class=\"p\">(<\/span><span class=\"n\">app<\/span><span class=\"p\">:<\/span> <span class=\"o\">&amp;<\/span><span class=\"n\">AppHandle<\/span><span class=\"o\">&lt;<\/span><span class=\"n\">Wry<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">,<\/span> <span class=\"n\">event<\/span><span class=\"p\">:<\/span> <span class=\"n\">SystemTrayEvent<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">match<\/span> <span class=\"n\">event<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nn\">SystemTrayEvent<\/span><span class=\"p\">::<\/span><span class=\"n\">MenuItemClick<\/span> <span class=\"p\">{<\/span> <span class=\"k\">ref<\/span> <span class=\"n\">id<\/span><span class=\"p\">,<\/span> <span class=\"o\">..<\/span> <span class=\"p\">}<\/span> <span class=\"k\">if<\/span> <span class=\"n\">id<\/span> <span class=\"o\">==<\/span> <span class=\"s\">\"quit\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nn\">std<\/span><span class=\"p\">::<\/span><span class=\"nn\">process<\/span><span class=\"p\">::<\/span><span class=\"nf\">exit<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">),<\/span>\r\n        <span class=\"nn\">SystemTrayEvent<\/span><span class=\"p\">::<\/span><span class=\"n\">MenuItemClick<\/span> <span class=\"p\">{<\/span> <span class=\"k\">ref<\/span> <span class=\"n\">id<\/span><span class=\"p\">,<\/span> <span class=\"o\">..<\/span> <span class=\"p\">}<\/span> <span class=\"k\">if<\/span> <span class=\"n\">id<\/span> <span class=\"o\">==<\/span> <span class=\"s\">\"hide\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"k\">let<\/span> <span class=\"n\">window<\/span> <span class=\"o\">=<\/span> <span class=\"n\">app<\/span><span class=\"nf\">.get_window<\/span><span class=\"p\">(<\/span><span class=\"s\">\"main\"<\/span><span class=\"p\">)<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n            <span class=\"n\">window<\/span><span class=\"nf\">.hide<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n        <span class=\"p\">},<\/span>\r\n        <span class=\"nn\">SystemTrayEvent<\/span><span class=\"p\">::<\/span><span class=\"n\">MenuItemClick<\/span> <span class=\"p\">{<\/span> <span class=\"k\">ref<\/span> <span class=\"n\">id<\/span><span class=\"p\">,<\/span> <span class=\"o\">..<\/span> <span class=\"p\">}<\/span> <span class=\"k\">if<\/span> <span class=\"n\">id<\/span> <span class=\"o\">==<\/span> <span class=\"s\">\"show\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"k\">let<\/span> <span class=\"n\">window<\/span> <span class=\"o\">=<\/span> <span class=\"n\">app<\/span><span class=\"nf\">.get_window<\/span><span class=\"p\">(<\/span><span class=\"s\">\"main\"<\/span><span class=\"p\">)<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n            <span class=\"n\">window<\/span><span class=\"nf\">.show<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n        <span class=\"p\">},<\/span>\r\n        <span class=\"n\">_<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"p\">{}<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.invoke_handler<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_handler!<\/span><span class=\"p\">[<\/span><span class=\"n\">get_entries<\/span><span class=\"p\">])<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u767b\u9332<\/span>\r\n        <span class=\"nf\">.system_tray<\/span><span class=\"p\">(<\/span><span class=\"nf\">create_systemtray<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.on_system_tray_event<\/span><span class=\"p\">(<\/span><span class=\"n\">on_system_tray_event<\/span><span class=\"p\">)<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u306e\u8a2d\u5b9a\u304c\u3042\u308b\u3053\u3068\u304b\u3089\u308f\u304b\u308b\u901a\u308a\u5e38\u99d0\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3068\u3057\u3066\u30a2\u30d7\u30ea\u3092\u4f5c\u6210\u3059\u308b\u3053\u3068\u3082\u53ef\u80fd\u3067\u3059\u3002setup\u30e1\u30bd\u30c3\u30c9\u3067\u6700\u521d\u306bhide\u3059\u308b\u3053\u3068\u3067\u30a6\u30a3\u30f3\u30c9\u30a6\u306a\u3057\u306e\u72b6\u614b\u304b\u3089\u30a2\u30d7\u30ea\u3092\u59cb\u3081\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.invoke_handler<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_handler!<\/span><span class=\"p\">[<\/span><span class=\"n\">get_entries<\/span><span class=\"p\">])<\/span>\r\n        <span class=\"nf\">.system_tray<\/span><span class=\"p\">(<\/span><span class=\"nf\">create_systemtray<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.on_system_tray_event<\/span><span class=\"p\">(<\/span><span class=\"n\">on_system_tray_event<\/span><span class=\"p\">)<\/span>\r\n\r\n        <span class=\"nf\">.setup<\/span><span class=\"p\">(|<\/span><span class=\"n\">app<\/span><span class=\"p\">|<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"c1\">\/\/ hide window on startup<\/span>\r\n            <span class=\"k\">let<\/span> <span class=\"n\">window<\/span> <span class=\"o\">=<\/span> <span class=\"n\">app<\/span><span class=\"nf\">.get_window<\/span><span class=\"p\">(<\/span><span class=\"s\">\"main\"<\/span><span class=\"p\">)<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n            <span class=\"n\">window<\/span><span class=\"nf\">.hide<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n\r\n            <span class=\"nf\">Ok<\/span><span class=\"p\">(())<\/span>\r\n        <span class=\"p\">})<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\u30a2\u30d7\u30eaDIY\u52e2\u3068\u3057\u3066\u306f\u5730\u5473\u306b\u3046\u308c\u3057\u3044\u6a5f\u80fd\u305f\u3061\u3067\u3057\u305f\u3002<\/p>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Window Menu | Tauri Apps<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">System Tray | Tauri Apps<\/ul>\n<h3>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3068\u30a4\u30d9\u30f3\u30c8\u7d4c\u7531\u306e\u76f8\u4e92\u4f5c\u7528<\/h3>\n<p>invoke\u306b\u3088\u3063\u3066TypeScript\u304b\u3089Rust\u306e\u95a2\u6570\u3092\u547c\u3076\u3053\u3068\u3067Rust\u5074\u306b\u5e72\u6e09\u3067\u304d\u307e\u3057\u305f\u3002\u3067\u306fRust\u304b\u3089TypeScript\u5074\u306b\u5e72\u6e09\u3059\u308b\u306b\u306f\u3069\u3046\u3059\u308c\u3070\u3088\u3044\u3067\u3057\u3087\u3046\u304b\uff1fTypeScript\u306e\u95a2\u6570\u3092Rust\u304b\u3089\u547c\u3073\u51fa\u3059\u306e\u306f\u4f55\u304b\u9055\u3046\u6c17\u304c\u3057\u307e\u3059\u3002<\/p>\n<p>\u3053\u3053\u3067\u767b\u5834\u3059\u308b\u306e\u304cRust\u304b\u3089TypeScript\u3078\u306e\u30a4\u30d9\u30f3\u30c8\u901a\u77e5\u306b\u306a\u308a\u307e\u3059\u3002\u6b21\u306e\u30b3\u30fc\u30c9\u306f\u3001\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u304c\u62bc\u3055\u308c\u305f\u6642\u306bTypeScript\u5074\u306b\u901a\u77e5\u3059\u308b\u4f8b\u3067\u3059\u3002emit_all\u3067\u30a4\u30d9\u30f3\u30c8\u540d\u3068\u5185\u5bb9\u3092\u5168\u30a6\u30a3\u30f3\u30c9\u30a6\u306b\u901a\u77e5\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">use<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::{<\/span><span class=\"n\">Manager<\/span><span class=\"p\">,<\/span> <span class=\"n\">AppHandle<\/span><span class=\"p\">,<\/span> <span class=\"n\">Wry<\/span><span class=\"p\">};<\/span>\r\n<span class=\"k\">use<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::{<\/span><span class=\"n\">SystemTray<\/span><span class=\"p\">,<\/span> <span class=\"n\">SystemTrayEvent<\/span><span class=\"p\">};<\/span>\r\n\r\n<span class=\"k\">use<\/span> <span class=\"nn\">std<\/span><span class=\"p\">::<\/span><span class=\"nn\">sync<\/span><span class=\"p\">::<\/span><span class=\"n\">Mutex<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"c1\">\/\/ \u30a4\u30d9\u30f3\u30c8\u901a\u77e5\u306b\u8f09\u305b\u308b\u4ed8\u52a0\u60c5\u5831\u306e\u578b<\/span>\r\n<span class=\"nd\">#[derive(Clone,<\/span> <span class=\"nd\">serde::Serialize)]<\/span>\r\n<span class=\"k\">struct<\/span> <span class=\"n\">Payload<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"n\">count<\/span><span class=\"p\">:<\/span> <span class=\"nb\">usize<\/span><span class=\"p\">,<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">on_system_tray_event<\/span><span class=\"p\">(<\/span><span class=\"n\">app<\/span><span class=\"p\">:<\/span> <span class=\"o\">&amp;<\/span><span class=\"n\">AppHandle<\/span><span class=\"o\">&lt;<\/span><span class=\"n\">Wry<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">,<\/span> <span class=\"n\">event<\/span><span class=\"p\">:<\/span> <span class=\"n\">SystemTrayEvent<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">match<\/span> <span class=\"n\">event<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nn\">SystemTrayEvent<\/span><span class=\"p\">::<\/span><span class=\"n\">LeftClick<\/span> <span class=\"p\">{<\/span> <span class=\"o\">..<\/span> <span class=\"p\">}<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"k\">let<\/span> <span class=\"n\">count_state<\/span><span class=\"p\">:<\/span> <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"n\">State<\/span><span class=\"o\">&lt;<\/span><span class=\"nv\">'_<\/span><span class=\"p\">,<\/span> <span class=\"n\">Mutex<\/span><span class=\"o\">&lt;<\/span><span class=\"nb\">usize<\/span><span class=\"o\">&gt;&gt;<\/span> <span class=\"o\">=<\/span> <span class=\"n\">app<\/span><span class=\"nf\">.state<\/span><span class=\"p\">();<\/span>\r\n            <span class=\"k\">let<\/span> <span class=\"k\">mut<\/span> <span class=\"n\">count<\/span> <span class=\"o\">=<\/span> <span class=\"n\">count_state<\/span><span class=\"nf\">.lock<\/span><span class=\"p\">()<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n            <span class=\"o\">*<\/span><span class=\"n\">count<\/span> <span class=\"o\">+=<\/span> <span class=\"mi\">1<\/span><span class=\"p\">;<\/span>\r\n\r\n            <span class=\"c1\">\/\/ \u5168\u30a6\u30a3\u30f3\u30c9\u30a6\u306b\u30a4\u30d9\u30f3\u30c8\u901a\u77e5<\/span>\r\n            <span class=\"n\">app<\/span><span class=\"nf\">.emit_all<\/span><span class=\"p\">(<\/span><span class=\"s\">\"system_tray_clicked\"<\/span><span class=\"p\">,<\/span> <span class=\"n\">Payload<\/span> <span class=\"p\">{<\/span>\r\n                <span class=\"n\">count<\/span><span class=\"p\">:<\/span> <span class=\"o\">*<\/span><span class=\"n\">count<\/span><span class=\"p\">,<\/span>\r\n            <span class=\"p\">})<\/span><span class=\"nf\">.unwrap<\/span><span class=\"p\">();<\/span>\r\n\r\n        <span class=\"p\">},<\/span>\r\n        <span class=\"n\">_<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"p\">{}<\/span>\r\n    <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">let<\/span> <span class=\"n\">state<\/span> <span class=\"o\">=<\/span> <span class=\"nn\">Mutex<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">(<\/span><span class=\"mi\">0_usize<\/span><span class=\"p\">);<\/span>\r\n\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u5404\u7a2e\u767b\u9332<\/span>\r\n        <span class=\"nf\">.manage<\/span><span class=\"p\">(<\/span><span class=\"n\">state<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"nf\">.system_tray<\/span><span class=\"p\">(<\/span><span class=\"nn\">SystemTray<\/span><span class=\"p\">::<\/span><span class=\"nf\">new<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.on_system_tray_event<\/span><span class=\"p\">(<\/span><span class=\"n\">on_system_tray_event<\/span><span class=\"p\">)<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u5074\u3067\u306flisten\u95a2\u6570\u3092\u4f7f\u3046\u3053\u3068\u3067\u30a4\u30d9\u30f3\u30c8\u901a\u77e5\u3092\u53d7\u3051\u53d6\u308c\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002listen\u306f\u30a4\u30d9\u30f3\u30c8\u76e3\u8996\u3092\u3084\u3081\u308b\u305f\u3081\u306e\u30cf\u30f3\u30c9\u30e9unlisten\u3092\u8fd4\u3059\u306e\u3067\u3001\u76e3\u8996\u3092\u6b62\u3081\u305f\u3044\u30bf\u30a4\u30df\u30f3\u30b0\u3067unlisten\u3092\u547c\u3076\u3088\u3046\u306b\u3057\u307e\u3059\u3002React\u306e\u5834\u5408useEffect\u3067\u30ea\u30c3\u30b9\u30f3\u3092\u958b\u59cb\u3057\u3001\u30af\u30ea\u30fc\u30f3\u30a2\u30c3\u30d7\u3067\u7d42\u4e86\u3059\u308b\u3068\u9069\u5207\u3067\u3057\u3087\u3046\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">useEffect<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useState<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">react<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">listen<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@tauri-apps\/api\/event<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">App<\/span> <span class=\"o\">=<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">count<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setCount<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useState<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">number<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"kd\">let<\/span> <span class=\"nx\">already_unmounted<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">false<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"kd\">let<\/span> <span class=\"nx\">unlisten<\/span> <span class=\"o\">=<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{};<\/span>\r\n\r\n    <span class=\"p\">(<\/span><span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"c1\">\/\/ \u30a4\u30d9\u30f3\u30c8\u30ea\u30c3\u30b9\u30f3\u958b\u59cb<\/span>\r\n      <span class=\"kd\">const<\/span> <span class=\"nx\">unlsn<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nx\">listen<\/span><span class=\"o\">&lt;<\/span><span class=\"p\">{<\/span> <span class=\"na\">count<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span> <span class=\"p\">}<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span>\r\n        <span class=\"dl\">\"<\/span><span class=\"s2\">system_tray_clicked<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"p\">(<\/span><span class=\"nx\">event<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n          <span class=\"nf\">setCount<\/span><span class=\"p\">(<\/span><span class=\"nx\">event<\/span><span class=\"p\">.<\/span><span class=\"nx\">payload<\/span><span class=\"p\">.<\/span><span class=\"nx\">count<\/span><span class=\"p\">);<\/span>\r\n        <span class=\"p\">}<\/span>\r\n      <span class=\"p\">);<\/span>\r\n\r\n      <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">already_unmounted<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"c1\">\/\/ await \u7d42\u4e86\u6642\u70b9\u3067\u30a2\u30f3\u30de\u30a6\u30f3\u30c8\u3055\u308c\u3066\u3044\u308b\u5834\u5408\u3059\u3050\u9589\u3058\u308b<\/span>\r\n        <span class=\"nf\">unlsn<\/span><span class=\"p\">();<\/span>\r\n      <span class=\"p\">}<\/span> <span class=\"k\">else<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nx\">unlisten<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">unlsn<\/span><span class=\"p\">;<\/span>\r\n      <span class=\"p\">}<\/span>\r\n    <span class=\"p\">})();<\/span>\r\n\r\n    <span class=\"k\">return <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nx\">already_unmounted<\/span> <span class=\"o\">=<\/span> <span class=\"kc\">true<\/span><span class=\"p\">;<\/span>\r\n\r\n      <span class=\"c1\">\/\/ \u30a4\u30d9\u30f3\u30c8\u30ea\u30c3\u30b9\u30f3\u7d42\u4e86<\/span>\r\n      <span class=\"nf\">unlisten<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"p\">};<\/span>\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[]);<\/span>\r\n\r\n  <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\r\n    <span class=\"p\">&lt;&gt;<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>count: <span class=\"si\">{<\/span><span class=\"nx\">count<\/span><span class=\"si\">}<\/span><span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;\/&gt;<\/span>\r\n  <span class=\"p\">);<\/span>\r\n<span class=\"p\">};<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">App<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<p>\u7b46\u8005\u306f\u4f7f\u308f\u306a\u3044\u305f\u3081\u7d39\u4ecb\u3057\u307e\u305b\u3093\u3067\u3057\u305f\u304c\u3001TypeScript\u304b\u3089Rust\u5074\u3078\u30a4\u30d9\u30f3\u30c8\u901a\u77e5\u3092\u9001\u308b\u3053\u3068\u3082\u53ef\u80fd\u3067\u3059\u3002invoke\u547c\u3073\u51fa\u3057\u3060\u3051\u3067\u826f\u304f\u306a\u3044&#8230;?<\/p>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">Events | Tauri Apps<\/ul>\n<h2>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9(TypeScript)\u7de8<\/h2>\n<p>Tauri\u306b\u306f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u5074\u304b\u3089\u4f7f\u7528\u3067\u304d\u308b\u4fbf\u5229\u306aAPI\u304c\u591a\u3005\u3042\u308a\u307e\u3059\u3002\u5168\u3066\u306f\u7d39\u4ecb\u3057\u307e\u305b\u3093\u304c\u3001\u3053\u306e\u3046\u3061\u304b\u3089\u3044\u304f\u3064\u304b\u629c\u7c8b\u3057\u3066\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n<p>@tauri-apps\/api\u4ee5\u4e0b\u306b\u3001app\u3001cli\u3001fs&#8230;\u3068\u3044\u3063\u305f\u5177\u5408\u306b\u305f\u304f\u3055\u3093\u306e\u30e2\u30b8\u30e5\u30fc\u30eb\u304c\u5b58\u5728\u3057\u307e\u3059\u3002\u5404\u30e2\u30b8\u30e5\u30fc\u30eb\u3092\u4f7f\u3046\u306b\u306ftauri.conf.json\u306etauri.allowlist\u4ee5\u4e0b\u3067\u660e\u793a\u7684\u306b\u8a31\u53ef\u3057\u306a\u3051\u308c\u3070\u306a\u3089\u306a\u3044\u5834\u5408\u304c\u3042\u308a\u307e\u3059\u3002\u306a\u308b\u3079\u304f\u30a2\u30d7\u30ea\u304c\u6301\u3064\u6a29\u9650\u3092\u5c11\u306a\u304f\u3059\u308b\u30db\u30ef\u30a4\u30c8\u30ea\u30b9\u30c8\u65b9\u5f0f\u3067\u3042\u308b\u305f\u3081\u3067\u3059\u3002<\/p>\n<h3>\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3068fs\u306e\u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58<\/h3>\n<p>\u4e00\u3064\u76ee\u306b\u7d39\u4ecb\u3059\u308b\u306e\u306ffs\u30e2\u30b8\u30e5\u30fc\u30eb\u306b\u3088\u308b\u30d5\u30a1\u30a4\u30eb\u306e\u8aad\u307f\u8fbc\u307f\u30fb\u4fdd\u5b58\u3067\u3059\u3002dialog\u30e2\u30b8\u30e5\u30fc\u30eb\u306eopen\u95a2\u6570\u3067Web\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3068\u540c\u69d8\u306b\u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58\u30c0\u30a4\u30a2\u30ed\u30b0\u3092\u51fa\u305b\u307e\u3059\u304c\u3001\u305b\u3063\u304b\u304f\u30ed\u30fc\u30ab\u30eb\u3067\u52d5\u4f5c\u3059\u308b\u30a2\u30d7\u30ea\u306a\u306e\u3067\u3059\u304b\u3089\u3001\u305d\u3061\u3089\u3067\u306f\u306a\u304f\u3001\u76f4\u63a5\u30d5\u30a1\u30a4\u30eb\u306b\u30a2\u30af\u30bb\u30b9\u3057\u8aad\u307f\u8fbc\u307f\u30fb\u4fdd\u5b58\u3067\u304d\u308b\u3088\u3046\u306a\u6a5f\u80fd\u3092\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n<p>fs\u30e2\u30b8\u30e5\u30fc\u30eb\u3092\u4f7f\u3046\u306b\u306ftauri.conf.json\u306eallowlist\u306bfs\u306e\u9805\u76ee\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"nl\">\"tauri\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n    <span class=\"nl\">\"allowlist\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nl\">\"all\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"nl\">\"fs\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nl\">\"all\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nl\">\"scope\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span><span class=\"s2\">\"$APPCONFIG\"<\/span><span class=\"p\">,<\/span> <span class=\"s2\">\"$APPCONFIG\/*\"<\/span><span class=\"p\">]<\/span>\r\n      <span class=\"p\">}<\/span>\r\n    <span class=\"p\">},<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>fs\u30e2\u30b8\u30e5\u30fc\u30eb\u72ec\u7279\u306a\u9805\u76ee\u306bscope\u304c\u3042\u308a\u307e\u3059\u3002\u6a5f\u80fd\u3068\u540c\u69d8\u306b\u3001\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308b\u30d5\u30a1\u30a4\u30eb\u30d1\u30b9\u3082\u30db\u30ef\u30a4\u30c8\u30ea\u30b9\u30c8\u65b9\u5f0f\u3068\u306a\u3063\u3066\u3044\u308b\u305f\u3081\u3067\u3059\u3002$APPCONFIG\u306e\u3088\u3046\u306a\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u5909\u6570\u306e\u4e00\u89a7\u306f\u516c\u5f0f\u306b\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u4e0a\u8a18\u4f8b\u3067\u306fscope\u306b\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u7528\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u6307\u5b9a\u3057\u3066\u3044\u307e\u3059\u3002\u30a2\u30d7\u30ea\u306e\u8a2d\u5b9a\u3092\u4fdd\u5b58\u3057\u3066\u304a\u304f\u7528\u9014\u3068\u3057\u3066fs\u30e2\u30b8\u30e5\u30fc\u30eb\u306b\u3088\u308b\u4fdd\u5b58\u306f\u3068\u3066\u3082\u4fbf\u5229\u3067\u3059\u3002<\/p>\n<p>React\u3092\u4f7f\u7528\u3057\u3066\u3044\u308b\u306a\u3089\u3070\u3001\u8a2d\u5b9a\u4fdd\u5b58\u306b\u306f\u5c02\u7528\u306e\u30ab\u30b9\u30bf\u30e0\u30d5\u30c3\u30af\u3092\u4f5c\u6210\u3059\u308b\u3068\u3001\u3044\u3044\u611f\u3058\u3067\u8a2d\u5b9a\u306e\u81ea\u52d5\u4fdd\u5b58\u6a5f\u80fd\u3092\u8a18\u8ff0\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u6b21\u306e\u30b3\u30fc\u30c9\u306f\u3001\u30a2\u30d7\u30ea\u7528\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea(C:\/Users\/YourName\/AppData\/Roaming\/AppName\u7b49)\u4ee5\u4e0b\u306bconfig.json\u3068\u3057\u3066\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3092\u6b8b\u3057\u3001\u5909\u66f4\u6642\u306b\u4fdd\u5b58\u3059\u308b\u3088\u3046\u306b\u3001\u307e\u305f\u3001\u5b58\u5728\u3059\u308c\u3070\u8d77\u52d5\u6642\u306b\u8aad\u307f\u8fbc\u3080\u3088\u3046\u306b\u3059\u308b\u4f8b\u3067\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"nx\">readTextFile<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">writeTextFile<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">exists<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">createDir<\/span><span class=\"p\">,<\/span>\r\n  <span class=\"nx\">BaseDirectory<\/span><span class=\"p\">,<\/span>\r\n<span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@tauri-apps\/api\/fs<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">useConfig<\/span> <span class=\"o\">=<\/span> <span class=\"p\">():<\/span> <span class=\"nx\">useConfigRes<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n  <span class=\"c1\">\/\/ \u521d\u671f\u5316\u6642<\/span>\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n    <span class=\"nx\">initializeAsyncFn<\/span><span class=\"p\">.<\/span><span class=\"nx\">current<\/span> <span class=\"o\">=<\/span> <span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"k\">try<\/span> <span class=\"p\">{<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u306e\u8aad\u307f\u8fbc\u307f<\/span>\r\n        <span class=\"kd\">const<\/span> <span class=\"nx\">profileBookStr<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nf\">readTextFile<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">config.json<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span>\r\n          <span class=\"na\">dir<\/span><span class=\"p\">:<\/span> <span class=\"nx\">BaseDirectory<\/span><span class=\"p\">.<\/span><span class=\"nx\">AppConfig<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"p\">});<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u30d1\u30fc\u30b9<\/span>\r\n        <span class=\"kd\">const<\/span> <span class=\"nx\">configFile<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">JSON<\/span><span class=\"p\">.<\/span><span class=\"nf\">parse<\/span><span class=\"p\">(<\/span><span class=\"nx\">profileBookStr<\/span><span class=\"p\">)<\/span> <span class=\"k\">as<\/span> <span class=\"nx\">Config<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"kd\">const<\/span> <span class=\"nx\">config<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span> <span class=\"p\">...<\/span><span class=\"nc\">DefaultConfig<\/span><span class=\"p\">(),<\/span> <span class=\"p\">...<\/span><span class=\"nx\">configFile<\/span> <span class=\"p\">};<\/span>\r\n        <span class=\"nf\">setConfig<\/span><span class=\"p\">(<\/span><span class=\"nx\">config<\/span><span class=\"p\">);<\/span>\r\n      \r\n      <span class=\"p\">}<\/span> <span class=\"k\">catch <\/span><span class=\"p\">(<\/span><span class=\"nx\">error<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"c1\">\/\/ \u521d\u56de\u306f\u30d5\u30a1\u30a4\u30eb\u304c\u306a\u3044\u306e\u3067\u30a8\u30e9\u30fc<\/span>\r\n        <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nf\">warn<\/span><span class=\"p\">(<\/span><span class=\"nx\">error<\/span><span class=\"p\">);<\/span>\r\n        <span class=\"nf\">setConfig<\/span><span class=\"p\">({<\/span>\r\n          <span class=\"p\">...<\/span><span class=\"nc\">DefaultConfig<\/span><span class=\"p\">(),<\/span>\r\n        <span class=\"p\">});<\/span>\r\n\r\n      <span class=\"p\">}<\/span>\r\n    <span class=\"p\">};<\/span>\r\n    <span class=\"nx\">initializeAsyncFn<\/span><span class=\"p\">.<\/span><span class=\"nf\">current<\/span><span class=\"p\">();<\/span>\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[]);<\/span>\r\n\r\n  <span class=\"c1\">\/\/ \u8a2d\u5b9a\u5909\u66f4\u6642<\/span>\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n    <span class=\"p\">(<\/span><span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n\r\n      <span class=\"c1\">\/\/ \u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u5b58\u5728\u30c1\u30a7\u30c3\u30af<\/span>\r\n      <span class=\"kd\">const<\/span> <span class=\"nx\">ext<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nf\">exists<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span> <span class=\"na\">dir<\/span><span class=\"p\">:<\/span> <span class=\"nx\">BaseDirectory<\/span><span class=\"p\">.<\/span><span class=\"nx\">AppConfig<\/span> <span class=\"p\">});<\/span>\r\n      <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">ext<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"k\">await<\/span> <span class=\"nf\">createDir<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"\"<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span> <span class=\"na\">dir<\/span><span class=\"p\">:<\/span> <span class=\"nx\">BaseDirectory<\/span><span class=\"p\">.<\/span><span class=\"nx\">AppConfig<\/span> <span class=\"p\">});<\/span>\r\n      <span class=\"p\">}<\/span>\r\n\r\n      <span class=\"c1\">\/\/ \u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3078\u306e\u66f8\u304d\u51fa\u3057<\/span>\r\n      <span class=\"k\">await<\/span> <span class=\"nf\">writeTextFile<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">config.json<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"nx\">JSON<\/span><span class=\"p\">.<\/span><span class=\"nf\">stringify<\/span><span class=\"p\">(<\/span><span class=\"nx\">config<\/span><span class=\"p\">),<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"na\">dir<\/span><span class=\"p\">:<\/span> <span class=\"nx\">BaseDirectory<\/span><span class=\"p\">.<\/span><span class=\"nx\">AppConfig<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"p\">});<\/span>\r\n\r\n    <span class=\"p\">})();<\/span>\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[<\/span><span class=\"nx\">config<\/span><span class=\"p\">]);<\/span>\r\n\r\n  <span class=\"k\">return<\/span> <span class=\"p\">[<\/span><span class=\"nx\">config<\/span><span class=\"p\">,<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">setUserName<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setAge<\/span> <span class=\"p\">}];<\/span>\r\n<span class=\"p\">};<\/span>\r\n\r\n<span class=\"c1\">\/\/ omit details<\/span>\r\n<\/code><\/pre>\n<details>\u5168\u4f53.\/hooks\/config-hook.ts<br \/>\nimport { useState, useEffect, useRef } from &#8220;react&#8221;;<br \/>\nimport {<br \/>\nreadTextFile,<br \/>\nwriteTextFile,<br \/>\nexists,<br \/>\ncreateDir,<br \/>\nBaseDirectory,<br \/>\n} from &#8220;@tauri-apps\/api\/fs&#8221;;<\/p>\n<p>export interface Config {<br \/>\nuserName: string;<br \/>\nage: number;<br \/>\n}<\/p>\n<p>const DefaultConfig = () =&gt; {<br \/>\nreturn {<br \/>\nuserName: &#8220;Anonymous&#8221;,<br \/>\nage: 0,<br \/>\n};<br \/>\n};<\/p>\n<p>export interface ConfigMethods {<br \/>\nsetUserName: (name: string) =&gt; void;<br \/>\nsetAge: (age: number) =&gt; void;<br \/>\n}<\/p>\n<p>type useConfigRes = [Config | undefined, ConfigMethods];<\/p>\n<p>const useConfig = (): useConfigRes =&gt; {<br \/>\nconst [config, setConfig] = useState(undefined);<\/p>\n<p>const setUserName = (name: string) =&gt; {<br \/>\nconst c = config ?? DefaultConfig();<br \/>\nc.userName = name;<br \/>\nsetConfig({ &#8230;c});<br \/>\n};<\/p>\n<p>const setAge = (age: number) =&gt; {<br \/>\nconst c = config ?? DefaultConfig();<br \/>\nc.age = age;<br \/>\nsetConfig({ &#8230;c});<br \/>\n};<\/p>\n<p>const initializeAsyncFn = useRef&lt;(() =&gt; Promise) | undefined&gt;(<br \/>\nundefined<br \/>\n);<\/p>\n<p>\/\/ \u521d\u671f\u5316\u6642<br \/>\nuseEffect(() =&gt; {<br \/>\nif (initializeAsyncFn.current !== undefined) {<br \/>\nreturn;<br \/>\n}<\/p>\n<p>initializeAsyncFn.current = async () =&gt; {<br \/>\ntry {<br \/>\n\/\/ \u30d5\u30a1\u30a4\u30eb\u30ed\u30fc\u30c9<br \/>\nconst profileBookStr = await readTextFile(&#8220;config.json&#8221;, {<br \/>\ndir: BaseDirectory.AppConfig,<br \/>\n});<br \/>\nconst configFile = JSON.parse(profileBookStr) as Config;<br \/>\nconst config = { &#8230;DefaultConfig(), &#8230;configFile };<br \/>\nsetConfig(config);<br \/>\n} catch (error) {<br \/>\nconsole.warn(error);<br \/>\nsetConfig({<br \/>\n&#8230;DefaultConfig(),<br \/>\n});<br \/>\n}<\/p>\n<p>console.log(&#8220;Config initialized&#8221;);<br \/>\n};<br \/>\ninitializeAsyncFn.current();<br \/>\n}, []);<\/p>\n<p>\/\/ \u8a2d\u5b9a\u5909\u66f4\u6642<br \/>\nuseEffect(() =&gt; {<br \/>\nif (config === undefined) {<br \/>\nreturn;<br \/>\n}<\/p>\n<p>(async () =&gt; {<br \/>\n\/\/ \u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58<br \/>\nconst ext = await exists(&#8220;&#8221;, { dir: BaseDirectory.AppConfig });<br \/>\nif (!ext) {<br \/>\nawait createDir(&#8220;&#8221;, { dir: BaseDirectory.AppConfig });<br \/>\n}<\/p>\n<p>await writeTextFile(&#8220;config.json&#8221;, JSON.stringify(config), {<br \/>\ndir: BaseDirectory.AppConfig,<br \/>\n});<br \/>\n})();<br \/>\n}, [config]);<\/p>\n<p>return [config, { setUserName, setAge }];<br \/>\n};<\/p>\n<p>export default useConfig;<\/p>\n<\/details>\n<details>\u30ab\u30b9\u30bf\u30e0\u30d5\u30c3\u30af\u4f7f\u7528\u4f8bApp.tsx<br \/>\nimport useConfig from &#8220;.\/hooks\/config-hook&#8221;;<\/p>\n<p>const App = () =&gt; {<br \/>\nconst [config, configMethods] = useConfig();<\/p>\n<p>return (<br \/>\n&lt;&gt;<br \/>\nUser Name: <input type=\"text\" value=\"{config?.userName\" \/> configMethods.setUserName(e.target.value)}\/&gt;<\/p>\n<p>User Age: <input type=\"number\" value=\"{config?.age\" \/> configMethods.setAge(parseInt(e.target.value))}\/&gt;<br \/>\n&lt;\/&gt;<br \/>\n);<br \/>\n}<\/p>\n<p>export default App;<\/p>\n<\/details>\n<p>readTextFile\u3067\u30d5\u30a1\u30a4\u30eb\u306e\u8aad\u307f\u8fbc\u307f\u3001writeTextFile\u3067\u30d5\u30a1\u30a4\u30eb\u306e\u66f8\u304d\u51fa\u3057\u304c\u3067\u304d\u307e\u3059\u3002\u307e\u305f\u3001\u4f8b\u3067\u306fJSON.parse\u3068JSON.stringify\u3092\u4f7f\u3063\u3066\u5927\u80c6\u306b\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u305d\u306e\u307e\u307e\u8aad\u307f\u8fbc\u307f\/\u5410\u304d\u3060\u3057\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>Rust\u306f\u4e00\u5207\u95a2\u308f\u3089\u305a\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u5074\u3067\u3059\u3079\u3066\u5b8c\u7d50\u3057\u6271\u3044\u3082\u5bb9\u6613\u3067\u3001\u30a2\u30d7\u30ea\u8a2d\u5b9a\u3092\u7c21\u5358\u306b\u8a2d\u8a08\u3067\u304d\u5b9f\u88c5\u304c\u6357\u308a\u307e\u3059\u3002<\/p>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">fs | Tauri Apps<\/ul>\n<h3>\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u3068\u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9\u306e\u6a5f\u80fd\u5b9f\u884c<\/h3>\n<p>Tauri\u88fd\u30bd\u30d5\u30c8\u304c\u305f\u3060WebView\u306b\u4f55\u304b\u3092\u8868\u793a\u3059\u308b\u3060\u3051\u306e\u30a2\u30d7\u30ea\u3060\u3063\u305f\u3089\u3053\u3053\u307e\u3067\u71b1\u4e2d\u3057\u3066\u3044\u306a\u304b\u3063\u305f\u304b\u3082\u3057\u308c\u306a\u3044&#8230;\u305d\u306e\u7b2c2\u5f3e\u3068\u306a\u308b\u6a5f\u80fd\u3067\u3059\u3002globalShortcut\/register\u3067\u30ad\u30fc\u30dc\u30fc\u30c9\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u3068\u305d\u308c\u306b\u7d50\u3073\u4ed8\u304f\u30cf\u30f3\u30c9\u30e9\u3092\u8a2d\u5b9a\u3067\u304d\u307e\u3059\u3002audio-bookmark\u3084win-win-map\u3067\u306f\u3053\u306e\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u6a5f\u80fd\u3092\u30d5\u30eb\u6d3b\u7528\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u3053\u3053\u307e\u3067\u306eAPI\u540c\u69d8\u3001\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u6a5f\u80fd\u3092\u30aa\u30f3\u306b\u3059\u308b\u305f\u3081\u306b\u306ftauri.conf.json\u306b\u8ffd\u8a18\u304c\u5fc5\u8981\u3067\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"nl\">\"tauri\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"allowlist\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"c1\">\/\/ omit details<\/span>\r\n      <span class=\"nl\">\"globalShortcut\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nl\">\"all\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span>\r\n      <span class=\"p\">}<\/span>\r\n    <span class=\"p\">},<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u6b21\u306e\u30b3\u30fc\u30c9\u306fCtrl+c\u3092\u62bc\u3059\u3068\u30ab\u30a6\u30f3\u30c8\u3059\u308b\u4f8b\u3067\u3059\u3002TypeScript\u3060\u3051\u3067\u304a\u624b\u8efd\u306b\u5b8c\u7d50\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">useState<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useEffect<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useRef<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">register<\/span><span class=\"p\">,<\/span> <span class=\"nx\">unregisterAll<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@tauri-apps\/api\/globalShortcut<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">App<\/span> <span class=\"o\">=<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">inner_count<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useRef<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">number<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"o\">-<\/span><span class=\"mi\">1<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">count<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setCount<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useState<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">number<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">inner_count<\/span><span class=\"p\">.<\/span><span class=\"nx\">current<\/span> <span class=\"o\">&gt;=<\/span> <span class=\"mi\">0<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"k\">return<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n    <span class=\"nx\">inner_count<\/span><span class=\"p\">.<\/span><span class=\"nx\">current<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span><span class=\"p\">;<\/span>\r\n\r\n    <span class=\"p\">(<\/span><span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n\r\n      <span class=\"c1\">\/\/ \u5168\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u306e\u89e3\u9664<\/span>\r\n      <span class=\"k\">await<\/span> <span class=\"nf\">unregisterAll<\/span><span class=\"p\">();<\/span>\r\n\r\n      <span class=\"c1\">\/\/ \u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u306e\u8a2d\u5b9a<\/span>\r\n      <span class=\"k\">await<\/span> <span class=\"nf\">register<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Ctrl+c<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nx\">inner_count<\/span><span class=\"p\">.<\/span><span class=\"nx\">current<\/span> <span class=\"o\">+=<\/span> <span class=\"mi\">1<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"nf\">setCount<\/span><span class=\"p\">(<\/span><span class=\"nx\">inner_count<\/span><span class=\"p\">.<\/span><span class=\"nx\">current<\/span><span class=\"p\">);<\/span>\r\n      <span class=\"p\">});<\/span>\r\n    <span class=\"p\">})();<\/span>\r\n\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[]);<\/span>\r\n\r\n  <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>count: <span class=\"si\">{<\/span><span class=\"nx\">count<\/span><span class=\"si\">}<\/span><span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">App<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<p>register\u95a2\u6570\u306e\u7b2c\u4e00\u5f15\u6570\u306b\u6e21\u3059\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u6587\u5b57\u5217\u306b\u95a2\u3059\u308b\u8a73\u7d30\u306a\u4ed5\u69d8(\u4fee\u98fe\u30ad\u30fc\u306b\u306f\u4f55\u304c\u6307\u5b9a\u3067\u304d\u308b\u304b\u7b49)\u304c\u898b\u3064\u304b\u3089\u306a\u304b\u3063\u305f\u306e\u3067\u3059\u304c\u3001\u8272\u3005\u8a66\u3057\u305f\u611f\u3058\u3067\u306fElectron\u306e\u3082\u306e\u3068\u540c\u69d8\u306e\u3088\u3046\u3067\u3059\u3002<\/p>\n<p>\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u6587\u5b57\u5217\u69cb\u7bc9\u7528\u306e\u95a2\u6570\u3092\u5b9a\u7fa9\u3057\u3066onKeyDown\u7b49\u306b\u8a2d\u5b9a\u3059\u308b\u3068\u6357\u308a\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">constructShortcut<\/span> <span class=\"o\">=<\/span> <span class=\"p\">(<\/span>\r\n  <span class=\"nx\">e<\/span><span class=\"p\">:<\/span> <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"nx\">KeyboardEvent<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">HTMLDivElement<\/span><span class=\"o\">&gt;<\/span>\r\n<span class=\"p\">):<\/span> <span class=\"kr\">string<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">shortcut_list<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[];<\/span>\r\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"nx\">altKey<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">shortcut_list<\/span><span class=\"p\">.<\/span><span class=\"nf\">push<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Alt<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"nx\">ctrlKey<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">shortcut_list<\/span><span class=\"p\">.<\/span><span class=\"nf\">push<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Control<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"nx\">shiftKey<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">shortcut_list<\/span><span class=\"p\">.<\/span><span class=\"nf\">push<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">Shift<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">shortcut_list<\/span><span class=\"p\">.<\/span><span class=\"nf\">indexOf<\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"nx\">key<\/span><span class=\"p\">)<\/span> <span class=\"o\">==<\/span> <span class=\"o\">-<\/span><span class=\"mi\">1<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">shortcut_list<\/span><span class=\"p\">.<\/span><span class=\"nf\">push<\/span><span class=\"p\">(<\/span><span class=\"nx\">e<\/span><span class=\"p\">.<\/span><span class=\"nx\">key<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"p\">}<\/span>\r\n\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">shortcut<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">shortcut_list<\/span><span class=\"p\">.<\/span><span class=\"nf\">join<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">+<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"k\">return<\/span> <span class=\"nx\">shortcut<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">};<\/span>\r\n<\/code><\/pre>\n<details>constructShortcut \u5229\u7528\u4f8b<br \/>\ninput\u8981\u7d20\u306eonKeyDown\u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9\u306b\u3066\u5229\u7528\u3057\u3066\u3044\u307e\u3059\u3002input\u8981\u7d20\u306b\u30d5\u30a9\u30fc\u30ab\u30b9\u304c\u5f53\u305f\u3063\u305f\u72b6\u614b\u3067\u30ad\u30fc\u30dc\u30fc\u30c9\u3067\u30ad\u30fc\u30d0\u30a4\u30f3\u30c9\u3092&#8221;\u305d\u306e\u307e\u307e&#8221;\u5165\u529b\u3059\u308b\u3068\u5e0c\u671b\u3057\u305f\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u304c\u8a18\u9332\u3055\u308c\u308b\u4ed5\u7d44\u307f\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<br \/>\nReact\u306b\u304a\u3051\u308b\u826f\u3044\u6392\u4ed6\u51e6\u7406\u306e\u66f8\u304d\u65b9\u304c\u308f\u304b\u3089\u305a\u5c11\u3057\u6c5a\u3044\u30b3\u30fc\u30c9\u306b\u306a\u308a\u307e\u3059\u3002\u3082\u3057\u826f\u3044\u66f8\u304d\u65b9\u3092\u3054\u5b58\u3058\u306e\u65b9\u304a\u308a\u307e\u3057\u305f\u3089\u30b3\u30e1\u30f3\u30c8\u3044\u305f\u3060\u3051\u308b\u3068\u5e78\u3044\u3067\u3059\u3002TypeScript<br \/>\nimport { useState, useEffect, useRef } from &#8216;react&#8217;;<br \/>\nimport { register, unregisterAll } from &#8220;@tauri-apps\/api\/globalShortcut&#8221;;<\/p>\n<p>const constructShortcut = (<br \/>\ne: React.KeyboardEvent<br \/>\n): string =&gt; {<br \/>\nconst shortcut_list = [];<br \/>\nif (e.altKey) {<br \/>\nshortcut_list.push(&#8220;Alt&#8221;);<br \/>\n}<br \/>\nif (e.ctrlKey) {<br \/>\nshortcut_list.push(&#8220;Control&#8221;);<br \/>\n}<br \/>\nif (e.shiftKey) {<br \/>\nshortcut_list.push(&#8220;Shift&#8221;);<br \/>\n}<\/p>\n<p>if (shortcut_list.indexOf(e.key) == -1) {<br \/>\nshortcut_list.push(e.key);<br \/>\n}<\/p>\n<p>const shortcut = shortcut_list.join(&#8220;+&#8221;);<\/p>\n<p>return shortcut;<br \/>\n};<\/p>\n<p>const App = () =&gt; {<br \/>\nconst inner_count = useRef(0);<br \/>\nconst mutex = useRef(false);<br \/>\nconst [count, setCount] = useState(0);<br \/>\nconst [shortcut, setShortcut] = useState(&#8220;Ctrl+c&#8221;);<\/p>\n<p>const registerShortcut = async (shortcut: string) =&gt; {<br \/>\nif (mutex.current) {<br \/>\nreturn;<br \/>\n}<br \/>\nmutex.current = true;<\/p>\n<p>try {<br \/>\nawait unregisterAll();<\/p>\n<p>await register(shortcut, () =&gt; {<br \/>\ninner_count.current += 1;<br \/>\nsetCount(inner_count.current);<br \/>\n});<br \/>\n} finally {<br \/>\nmutex.current = false;<br \/>\n}<br \/>\n};<\/p>\n<p>useEffect(() =&gt; {<br \/>\n(async () =&gt; {<br \/>\nawait registerShortcut(shortcut);<br \/>\n})();<br \/>\n}, [shortcut]);<\/p>\n<p>return (<br \/>\n&lt;&gt;<\/p>\n<div>count: {count}<\/div>\n<p><input type=\"text\" value=\"{shortcut}\" \/> {<br \/>\nconst s = constructShortcut(e);<br \/>\nsetShortcut(s);<br \/>\n}}<br \/>\n\/&gt;<br \/>\n&lt;\/&gt;<br \/>\n);<br \/>\n}<\/p>\n<p>export default App;<\/p>\n<\/details>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">globalShortcut | Tauri Apps<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Accelerator | Electron<\/ul>\n<h3>\u30e6\u30fc\u30b6\u30fc\u3068OS\u306e\u30a2\u30d7\u30ea\u901a\u77e5<\/h3>\n<p>Tauri\u306a\u3089\u3070\u3001\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u7b49\u306b\u4e26\u3073\u30ab\u30c3\u30b3\u3044\u3044\u6a5f\u80fd\u3067\u3042\u308b\u30a2\u30d7\u30ea\u901a\u77e5\u3082\u7c21\u5358\u306b\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/153-0.png\" alt=\"image.png\" \/><\/div>\n<p>\u305f\u3060\u3057\u4f8b\u306b\u3088\u3063\u3066\u6700\u521d\u306b\u5c0f\u7d30\u5de5\u304c\u5fc5\u8981\u3067\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"nl\">\"tauri\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"allowlist\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"c1\">\/\/ omit details<\/span>\r\n      <span class=\"nl\">\"notification\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"nl\">\"all\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span>\r\n      <span class=\"p\">}<\/span>\r\n    <span class=\"p\">},<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>sendNotification\u3068\u3044\u3046\u95a2\u6570\u3092\u3001\u7b2c\u4e00\u5f15\u6570\u306b\u901a\u77e5\u30bf\u30a4\u30c8\u30eb\u3001\u7b2c\u4e8c\u5f15\u6570\u306b\u5185\u5bb9\u3092\u6307\u5b9a\u3057\u3066\u547c\u3073\u51fa\u3059\u3053\u3068\u3067\u3001\u753b\u50cf\u306b\u793a\u3057\u305f\u3088\u3046\u306a\u901a\u77e5\u304c\u884c\u3048\u307e\u3059\u3002<\/p>\n<p>OS\u306b\u901a\u77e5\u8a31\u53ef\u3092\u5f97\u308b\u51e6\u7406\u304c\u5fc5\u8981\u306a\u305f\u3081\u3001\u3053\u306e\u51e6\u7406\u3092\u5408\u308f\u305b\u3066\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u30d5\u30a1\u30a4\u30eb\u306b\u72ec\u7acb\u3055\u305b\u3066\u5b9a\u7fa9\u3057\u3066\u304a\u304f\u3068\u6271\u3044\u3084\u3059\u3044\u3067\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">isPermissionGranted<\/span><span class=\"p\">,<\/span> <span class=\"nx\">requestPermission<\/span><span class=\"p\">,<\/span> <span class=\"nx\">sendNotification<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">@tauri-apps\/api\/notification<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">async<\/span> <span class=\"kd\">function<\/span> <span class=\"nf\">initNotification<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">await<\/span> <span class=\"nf\">checkPermission<\/span><span class=\"p\">();<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">async<\/span> <span class=\"kd\">function<\/span> <span class=\"nf\">checkPermission<\/span><span class=\"p\">():<\/span> <span class=\"nb\">Promise<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">boolean<\/span><span class=\"o\">&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"kd\">let<\/span> <span class=\"nx\">permissionGranted<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nf\">isPermissionGranted<\/span><span class=\"p\">();<\/span>\r\n    <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">permissionGranted<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"kd\">const<\/span> <span class=\"nx\">permission<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nf\">requestPermission<\/span><span class=\"p\">();<\/span>\r\n        <span class=\"nx\">permissionGranted<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">permission<\/span> <span class=\"o\">===<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">granted<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"nx\">permissionGranted<\/span><span class=\"p\">;<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">async<\/span> <span class=\"kd\">function<\/span> <span class=\"nf\">showNotification<\/span><span class=\"p\">(<\/span><span class=\"nx\">title<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">,<\/span> <span class=\"nx\">body<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"p\">(<\/span><span class=\"k\">await<\/span> <span class=\"nf\">checkPermission<\/span><span class=\"p\">()))<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"k\">return<\/span><span class=\"p\">;<\/span>\r\n    <span class=\"p\">}<\/span>\r\n\r\n    <span class=\"k\">await<\/span> <span class=\"nf\">sendNotification<\/span><span class=\"p\">({<\/span>\r\n        <span class=\"nx\">title<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nx\">body<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"p\">});<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<details>\u547c\u3073\u51fa\u3057\u4f8bTypeScript<br \/>\nimport { showNotification } from &#8220;.\/notification&#8221;;<\/p>\n<p>const App = () =&gt; {<br \/>\nreturn (<br \/>\n&lt;&gt;<br \/>\n<button> showNotification(&#8220;Hello!&#8221;, &#8220;from tauri&#8221;)}&gt;Show Notification<\/button><br \/>\n&lt;\/&gt;<br \/>\n);<br \/>\n}<\/p>\n<p>export default App;<\/p>\n<\/details>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">notification | Tauri Apps<\/ul>\n<h2>Tauri\u7de8<\/h2>\n<p>\u6700\u5f8c\u306eTauri\u7de8\u3067\u306f\u5206\u985e\u3057\u3065\u3089\u304b\u3063\u305f\u308a\u6a5f\u80fd\u9762\u4ee5\u5916\u3067\u4fbf\u5229\u306a\u3082\u306e\u3067\u3042\u3063\u305f\u308a\u7b49\u3092\u7d39\u4ecb\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<h3>CLI\u3068\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u306e\u5f15\u6570\u6307\u5b9a<\/h3>\n<p>\u3053\u3053\u3067\u7d39\u4ecb\u3059\u308b\u306e\u306f\u30a2\u30d7\u30ea\u304c\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u5f15\u6570\u3092\u53d7\u3051\u53d6\u308c\u308b\u3088\u3046\u306b\u3059\u308b\u6a5f\u80fd\u3067\u3059\u3002\u672c\u6a5f\u80fd\u306f\u5b9f\u306f\u672c\u8a18\u4e8b\u306e\u57f7\u7b46\u3092\u6c7a\u3081\u3066\u304b\u3089\u8a66\u3057\u305f\u306e\u3067\u3059\u304c\u3001\u30cf\u30f3\u30ba\u30aa\u30f3\u6642\u70b9\u3067\u53d6\u308a\u7d44\u3081\u3066\u3044\u306a\u304b\u3063\u305f&amp;\u3068\u3066\u3082\u4fbf\u5229\u306a\u6a5f\u80fd\u3068\u611f\u3058\u305f\u305f\u3081\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n<div>\n<p>\u300cGUI\u30a2\u30d7\u30ea\u306a\u306e\u306b\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u5f15\u6570\u8981\u3089\u306a\u304f\u306a\u3044\uff1f\u8aad\u307f\u98db\u3070\u305d\u3046\u300d\u3068\u601d\u3063\u305f\u305d\u3053\u306e\u3042\u306a\u305f\uff01\u3042\u306a\u305f\u306e\u305f\u3081\u306b\u3053\u3053\u306b\u66f8\u304f\u3068\u3001GUI\u306e\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u5f15\u6570\u306f(\u5c11\u306a\u304f\u3068\u3082Windows\u3067\u306f)\u6b21\u306e\u3088\u3046\u306a\u30b7\u30fc\u30f3\u3067\u4f7f\u3048\u307e\u3059\u3002<\/p>\n<p>\u30d5\u30a1\u30a4\u30eb\u3092\u53f3\u30af\u30ea\u30c3\u30af\u3057\u3066\u51fa\u308b\u30b3\u30f3\u30c6\u30ad\u30b9\u30c8\u30e1\u30cb\u30e5\u30fc\u306e\u300c\u30d7\u30ed\u30b0\u30e9\u30e0\u304b\u3089\u958b\u304f\u300d\u3067\u30a2\u30d7\u30ea\u3092\u6307\u5b9a\u3059\u308b\u3068\u304d<br \/>\n\u30a2\u30d7\u30ea\u306e\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u306b\u30d5\u30a1\u30a4\u30eb\u3092D&amp;D\u3057\u305f\u3068\u304d<\/p>\n<p>\u4e0a\u8a18\u306e\u30b7\u30fc\u30f3\u3067\u306f\u30a2\u30d7\u30ea\u306e\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u5f15\u6570\u306b\u30d5\u30a1\u30a4\u30eb\u30d1\u30b9\u304c\u6e21\u3055\u308c\u307e\u3059\u3002\u7279\u5b9a\u306e\u62e1\u5f35\u5b50\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u6271\u3046\u30a2\u30d7\u30ea\u7b49\u3092\u4f5c\u308b\u306a\u3089\u3070\u307b\u3057\u3044\u6a5f\u80fd\u306b\u601d\u3048\u3066\u304d\u307e\u305b\u3093\u304b&#8230;?<\/p>\n<\/div>\n<p>\u6bce\u5ea6\u306e\u901a\u308atauri.conf.json\u306b\u8a2d\u5b9a\u3092\u8ffd\u8a18\u3059\u308b\u3053\u3068\u3067\u4f7f\u7528\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002\u305f\u3060\u3057allowlist\u306b\u5165\u308c\u308b\u306e\u3067\u306f\u306a\u304f\u3001\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u3068\u540c\u69d8\u306btauri\u76f4\u4e0b\u306e\u4e00\u8981\u7d20\u3068\u3057\u3066\u8ffd\u8a18\u3057\u307e\u3059\u3002\u3053\u306e\u4f8b\u3067\u306f\u3001filepath\u3068\u3044\u3046\u540d\u524d\u306e\u5f15\u6570\u3092\u53d7\u3051\u53d6\u308c\u308b\u3088\u3046\u306b\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"nl\">\"tauri\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nl\">\"cli\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nl\">\"description\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"dsc\"<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"nl\">\"longDescription\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"long dsc\"<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"nl\">\"beforeHelp\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"before help\"<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"nl\">\"afterHelp\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"after help\"<\/span><span class=\"p\">,<\/span>\r\n      <span class=\"nl\">\"args\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\r\n        <span class=\"p\">{<\/span>\r\n          <span class=\"nl\">\"name\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"filepath\"<\/span><span class=\"p\">,<\/span>\r\n          <span class=\"nl\">\"index\"<\/span><span class=\"p\">:<\/span> <span class=\"mi\">1<\/span><span class=\"p\">,<\/span>\r\n          <span class=\"nl\">\"takesValue\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span>\r\n        <span class=\"p\">}<\/span>\r\n      <span class=\"p\">]<\/span>\r\n    <span class=\"p\">}<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u53d7\u3051\u53d6\u3063\u305f\u5f15\u6570\u306fRust\u3001TypeScript\u306e\u53cc\u65b9\u304b\u3089\u78ba\u8a8d\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.invoke_handler<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_handler!<\/span><span class=\"p\">[<\/span><span class=\"n\">get_entries<\/span><span class=\"p\">])<\/span>\r\n\r\n        <span class=\"nf\">.setup<\/span><span class=\"p\">(|<\/span><span class=\"n\">app<\/span><span class=\"p\">|<\/span> <span class=\"p\">{<\/span>\r\n\r\n            <span class=\"c1\">\/\/ \u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u5f15\u6570\u306e\u53d6\u5f97<\/span>\r\n            <span class=\"k\">let<\/span> <span class=\"nf\">Ok<\/span><span class=\"p\">(<\/span><span class=\"n\">matches<\/span><span class=\"p\">)<\/span> <span class=\"o\">=<\/span> <span class=\"n\">app<\/span><span class=\"nf\">.get_cli_matches<\/span><span class=\"p\">()<\/span> <span class=\"k\">else<\/span> <span class=\"p\">{<\/span> <span class=\"k\">return<\/span> <span class=\"nf\">Ok<\/span><span class=\"p\">(())<\/span> <span class=\"p\">};<\/span>\r\n\r\n            <span class=\"nd\">println!<\/span><span class=\"p\">(<\/span><span class=\"s\">\"CLI matches: {:?}\"<\/span><span class=\"p\">,<\/span> <span class=\"n\">matches<\/span><span class=\"p\">);<\/span>\r\n\r\n            <span class=\"nf\">Ok<\/span><span class=\"p\">(())<\/span>\r\n        <span class=\"p\">})<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">useState<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useEffect<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">getMatches<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">@tauri-apps\/api\/cli<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">App<\/span> <span class=\"o\">=<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">matches<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setMatches<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useState<\/span><span class=\"o\">&lt;<\/span><span class=\"kr\">string<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">-<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"p\">(<\/span><span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n\r\n      <span class=\"c1\">\/\/ \u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u5f15\u6570\u306e\u53d6\u5f97<\/span>\r\n      <span class=\"kd\">const<\/span> <span class=\"nx\">m<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nf\">getMatches<\/span><span class=\"p\">();<\/span>\r\n      <span class=\"nf\">setMatches<\/span><span class=\"p\">(<\/span><span class=\"nx\">m<\/span><span class=\"p\">.<\/span><span class=\"nx\">args<\/span><span class=\"p\">.<\/span><span class=\"nx\">filepath<\/span><span class=\"p\">?.<\/span><span class=\"nx\">value<\/span><span class=\"p\">?.<\/span><span class=\"nf\">toString<\/span><span class=\"p\">()<\/span> <span class=\"o\">??<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">-<\/span><span class=\"dl\">\"<\/span><span class=\"p\">);<\/span>\r\n\r\n    <span class=\"p\">})();<\/span>\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[]);<\/span>\r\n\r\n  <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\r\n    <span class=\"p\">&lt;&gt;<\/span>Arg: <span class=\"si\">{<\/span><span class=\"nx\">matches<\/span><span class=\"si\">}<\/span><span class=\"p\">&lt;\/&gt;<\/span>\r\n  <span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">App<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<p>yarn tauri dev\u30b3\u30de\u30f3\u30c9\u306b\u3088\u308a\u672c\u6a5f\u80fd\u3092\u8a66\u3059\u306b\u306f\u3061\u3087\u3063\u3068\u5de5\u592b\u304c\u5fc5\u8981\u3067\u3059\u3002cargo\u306a\u3069\u3001\u5185\u90e8\u3067\u5225\u306a\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3059\u308b\u30bf\u30a4\u30d7\u306e\u30b3\u30de\u30f3\u30c9\u3067\u306f\u5185\u90e8\u30b3\u30de\u30f3\u30c9\u306b\u6e21\u3059\u5f15\u6570\u3092\u8868\u3059\u306e\u306b&#8211;\u3092\u9593\u306b\u5165\u308c\u307e\u3059\u304c\u3001\u7b46\u8005\u306e\u74b0\u5883\u3067\u306f\u3053\u308c\u30924\u3064\u5165\u308c\u308b\u3068\u4e0a\u624b\u304f\u6e21\u3059\u3053\u3068\u304c\u53ef\u80fd\u3067\u3057\u305f\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"err\">&gt;<\/span> <span class=\"n\">yarn<\/span> <span class=\"nx\">tauri<\/span> <span class=\"nx\">dev<\/span> <span class=\"o\">--<\/span> <span class=\"o\">--<\/span> <span class=\"o\">--<\/span> <span class=\"o\">--<\/span> <span class=\"nx\">commandlinearg<\/span>\r\n<\/code><\/pre>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">Making Your Own CLI | Tauri Apps<\/ul>\n<h3>\u30d7\u30e9\u30b0\u30a4\u30f3\u3068\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u81ea\u52d5\u59cb\u52d5<\/h3>\n<p>\u672c\u7bc0\u3067\u306ftauri-plugin-autostart\u3068\u3044\u3046\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u7d39\u4ecb\u3057\u307e\u3059\u3002\u672c\u6a5f\u80fd\u3092\u5c0e\u5165\u3059\u308b\u3068\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d77\u3092\u30a2\u30d7\u30ea\u5074\u304b\u3089\u767b\u9332\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p>OS\u8d77\u52d5\u6642\u306b\u30a2\u30d7\u30ea\u3092\u8d77\u52d5\u3067\u304d\u308b\u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d7\u306f\u3001\u7b46\u8005\u304c\u4f5c\u3063\u305f\u3088\u3046\u306a\u5e38\u99d0\u7cfb\u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\u30a2\u30d7\u30ea\u306b\u306f\u3068\u3066\u3082\u4fbf\u5229\u306a\u6a5f\u80fd\u3067\u3059\u3002\u305f\u3060\u30d7\u30e9\u30b0\u30a4\u30f3\u3067\u3042\u308b\u90fd\u5408\u4e0a\u5c0e\u5165\u307e\u3067\u304c\u4ed6\u306e\u6a5f\u80fd\u3088\u308a\u3082\u9762\u5012\u3067\u306f\u3042\u308a\u307e\u3059\u3002\u9806\u306b\u8aac\u660e\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n<p>Tauri\u306b\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u5c0e\u5165\u3057\u3066\u3044\u304d\u307e\u3059\u3002\u307e\u305a\u3001Cargo.toml\u306b\u3066tauri-plugin-autostart\u30af\u30ec\u30fc\u30c8\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># omit detail<\/span>\r\n\r\n<span class=\"nn\">[dependencies]<\/span>\r\n<span class=\"c\"># omit details<\/span>\r\n<span class=\"hil\"><span class=\"o\">+ <\/span><span class=\"nn\">tauri-plugin-autostart<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span> <span class=\"py\">git<\/span> <span class=\"p\">=<\/span> <span class=\"s\">\"https:\/\/github.com\/tauri-apps\/plugins-workspace\"<\/span><span class=\"p\">,<\/span> <span class=\"py\">branch<\/span> <span class=\"p\">=<\/span> <span class=\"s\">\"dev\"<\/span> <span class=\"p\">}<\/span>\r\n<\/span><\/code><\/pre>\n<p>\u30d5\u30ed\u30f3\u30c8\u5074\u304b\u3089\u3082\u4f7f\u3046\u30d7\u30e9\u30b0\u30a4\u30f3\u306e\u305f\u3081\u3001TS\u5074\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u3082\u8ffd\u52a0\u3057\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"err\">&gt;<\/span> <span class=\"n\">yarn<\/span> <span class=\"nx\">add<\/span> <span class=\"nx\">https:\/\/github.com\/tauri-apps\/tauri-plugin-autostart<\/span>\r\n<\/code><\/pre>\n<div>\n<p>\u672c\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u8ffd\u52a0\u306b\u306fgit\u304c\u3042\u3089\u304b\u3058\u3081\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u3066\u3044\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<br \/>\n\u307e\u305f\u3001\u5f8c\u8ff0\u306eGitHub Actions\u306b\u3066\u6ede\u308a\u306a\u304f\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u305f\u3081\u306b\u3001package.json\u3067\u306fssh\u3067\u306f\u306a\u304fhttps\u3067\u53d6\u5f97\u3059\u308b\u3088\u3046\u306b\u66f8\u304b\u308c\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n<\/div>\n<p>\u4e0b\u6e96\u5099\u306e\u6700\u5f8c\u306b\u3001Rust\u5074\u3067Tauri\u30d3\u30eb\u30c0\u30fc\u306bplugin\u3092\u767b\u9332\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"k\">use<\/span> <span class=\"nn\">tauri_plugin_autostart<\/span><span class=\"p\">::<\/span><span class=\"n\">MacosLauncher<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">fn<\/span> <span class=\"nf\">main<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nn\">Builder<\/span><span class=\"p\">::<\/span><span class=\"nf\">default<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nf\">.invoke_handler<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_handler!<\/span><span class=\"p\">[<\/span><span class=\"n\">get_entries<\/span><span class=\"p\">])<\/span>\r\n\r\n        <span class=\"c1\">\/\/ \u30d7\u30e9\u30b0\u30a4\u30f3\u9069\u7528<\/span>\r\n        <span class=\"nf\">.plugin<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri_plugin_autostart<\/span><span class=\"p\">::<\/span><span class=\"nf\">init<\/span><span class=\"p\">(<\/span><span class=\"nn\">MacosLauncher<\/span><span class=\"p\">::<\/span><span class=\"n\">LaunchAgent<\/span><span class=\"p\">,<\/span> <span class=\"nb\">None<\/span><span class=\"p\">))<\/span>\r\n\r\n        <span class=\"nf\">.run<\/span><span class=\"p\">(<\/span><span class=\"nn\">tauri<\/span><span class=\"p\">::<\/span><span class=\"nd\">generate_context!<\/span><span class=\"p\">())<\/span>\r\n        <span class=\"nf\">.expect<\/span><span class=\"p\">(<\/span><span class=\"s\">\"error while running tauri application\"<\/span><span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>\u7b2c\u4e00\u5f15\u6570\u306fMacOS\u7528\u306e\u3082\u306e\u3067\u3059\u304c\u307b\u304b\u306e\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u3067\u3082\u6307\u5b9a\u5fc5\u9808\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u7b2c\u4e8c\u5f15\u6570\u306f\u8d77\u52d5\u6642\u306b\u6e21\u3059\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u5f15\u6570\u3092\u6307\u5b9a\u3059\u308b\u3082\u306e\u3067\u3059\u3002<\/p>\n<p>\u3053\u3053\u307e\u3067\u8a2d\u5b9a\u3059\u308b\u3053\u3068\u3067\u3001TypeScript\u5074\u304b\u3089\u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d7\u306e\u8a2d\u5b9a\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">enable<\/span><span class=\"p\">,<\/span> <span class=\"nx\">isEnabled<\/span><span class=\"p\">,<\/span> <span class=\"nx\">disable<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">tauri-plugin-autostart-api<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">useEffect<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useState<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">react<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">App<\/span> <span class=\"o\">=<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">asState<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setAsState<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useState<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">boolean<\/span> <span class=\"o\">|<\/span> <span class=\"kc\">undefined<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">(<\/span><span class=\"kc\">undefined<\/span><span class=\"p\">);<\/span>\r\n\r\n  <span class=\"nf\">useEffect<\/span><span class=\"p\">(()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"p\">(<\/span><span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n      <span class=\"nf\">setAsState<\/span><span class=\"p\">(<\/span><span class=\"k\">await<\/span> <span class=\"nf\">isEnabled<\/span><span class=\"p\">());<\/span>\r\n    <span class=\"p\">})();<\/span>\r\n  <span class=\"p\">},<\/span> <span class=\"p\">[]);<\/span>\r\n\r\n  <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\r\n    <span class=\"p\">&lt;&gt;<\/span>\r\n      <span class=\"si\">{<\/span><span class=\"nx\">asState<\/span> <span class=\"o\">!==<\/span> <span class=\"kc\">undefined<\/span> <span class=\"p\">?<\/span> <span class=\"p\">&lt;&gt;<\/span>\r\n        <span class=\"p\">&lt;<\/span><span class=\"nt\">p<\/span><span class=\"p\">&gt;<\/span>Autostart is <span class=\"si\">{<\/span><span class=\"nx\">asState<\/span> <span class=\"p\">?<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">enabled<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">disabled<\/span><span class=\"dl\">\"<\/span><span class=\"si\">}<\/span><span class=\"p\">&lt;\/<\/span><span class=\"nt\">p<\/span><span class=\"p\">&gt;<\/span>\r\n        <span class=\"p\">&lt;<\/span><span class=\"nt\">button<\/span> <span class=\"na\">onClick<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n          <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">asState<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"nf\">disable<\/span><span class=\"p\">();<\/span>\r\n          <span class=\"p\">}<\/span> <span class=\"k\">else<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"nf\">enable<\/span><span class=\"p\">();<\/span>\r\n          <span class=\"p\">}<\/span>\r\n          <span class=\"nf\">setAsState<\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">asState<\/span><span class=\"p\">);<\/span>\r\n        <span class=\"p\">}<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n          <span class=\"si\">{<\/span><span class=\"nx\">asState<\/span> <span class=\"p\">?<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">Disable<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">Enable<\/span><span class=\"dl\">\"<\/span><span class=\"si\">}<\/span> Autostart\r\n        <span class=\"p\">&lt;\/<\/span><span class=\"nt\">button<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;\/&gt;<\/span> <span class=\"p\">:<\/span> <span class=\"p\">&lt;&gt;<\/span>loading...<span class=\"p\">&lt;\/&gt;<\/span><span class=\"si\">}<\/span>\r\n    <span class=\"p\">&lt;\/&gt;<\/span>\r\n  <span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">App<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<p>\u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d7\u306e\u72b6\u6cc1\u3092\u53d6\u5f97\u3059\u308bisEnabled\u306f\u975e\u540c\u671f\u95a2\u6570\u306e\u305f\u3081\u3001useEffect\u5185\u3067\u53d6\u5f97\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>yarn tauri dev\u3067\u306f\u306a\u304f\u3001yarn tauri build\u3067\u751f\u6210\u3055\u308c\u308b\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u30fc(\u5f8c\u8ff0)\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u78ba\u304b\u3081\u308b\u3068\u52b9\u679c\u3092\u78ba\u8a8d\u3057\u3084\u3059\u3044\u3067\u3059\u3002\u6709\u52b9\u306b\u306a\u3063\u3066\u3044\u308c\u3070\u3001\u8a2d\u5b9a &gt; \u30a2\u30d7\u30ea &gt; \u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d7\u304b\u3089\u78ba\u8a8d\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u308b\u306f\u305a\u3067\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/191-0.png\" alt=\"image.png\" \/><\/div>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">tauri-apps\/tauri-plugin-autostart<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Tauri Plugins | Tauri Apps<\/ul>\n<h3>\u6a5f\u80fd\u5206\u5272\u3068URL\u6307\u5b9a\u306e\u30de\u30eb\u30c1\u30a6\u30a3\u30f3\u30c9\u30a6<\/h3>\n<p>GUI\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3068\u8a00\u3048\u3070\u3001\u30b7\u30f3\u30b0\u30eb\u30a6\u30a3\u30f3\u30c9\u30a6\u3060\u3051\u3067\u306f\u306a\u304f\u3001\u8a2d\u5b9a\u30a6\u30a3\u30f3\u30c9\u30a6\u3084\u30a2\u30e9\u30fc\u30c8\u3001\u30c4\u30fc\u30eb\u30bf\u30d6\u306a\u3069\u3001\u3044\u304f\u3064\u304b\u306e\u30a6\u30a3\u30f3\u30c9\u30a6\u306b\u5206\u304b\u308c\u3066\u3044\u308b\u3053\u3068\u304c\u3057\u3070\u3057\u3070\u3067\u3059\u3002\u4f8b\u3048\u3070AviUtl\u306a\u3093\u304b\u306f\u30a6\u30a3\u30f3\u30c9\u30a6\u307e\u307f\u308c\u3067\u3059\u3002<\/p>\n<p>Tauri\u3067\u3082\u8907\u6570\u306e\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u751f\u6210\u3059\u308b\u3053\u3068\u304c\u53ef\u80fd\u3067\u3059\u3002<\/p>\n<h4>\u9759\u7684\u306b\u30a6\u30a3\u30f3\u30c9\u30a6\u751f\u6210<\/h4>\n<p>\u57fa\u672c\u7684\u306a\u5897\u3084\u3057\u65b9\u3068\u3057\u3066\u3001tauri.conf.json\u306b\u8ffd\u8a18\u3059\u308b\u3060\u3051\u3067\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u5897\u3084\u305b\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"p\">{<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"nl\">\"tauri\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n    <span class=\"nl\">\"windows\"<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\r\n      <span class=\"p\">{<\/span>\r\n        <span class=\"nl\">\"fullscreen\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">false<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nl\">\"resizable\"<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nl\">\"title\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"tauri-react-player\"<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nl\">\"width\"<\/span><span class=\"p\">:<\/span> <span class=\"mi\">800<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nl\">\"height\"<\/span><span class=\"p\">:<\/span> <span class=\"mi\">600<\/span>\r\n      <span class=\"p\">},<\/span>\r\n      <span class=\"c1\">\/\/ \u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u8ffd\u52a0<\/span>\r\n      <span class=\"p\">{<\/span>\r\n        <span class=\"nl\">\"label\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"subwindow\"<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"nl\">\"title\"<\/span><span class=\"p\">:<\/span> <span class=\"s2\">\"Sub Window\"<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"c1\">\/\/ \"url\": \"sub.html\" \/\/ \u5f8c\u8ff0<\/span>\r\n      <span class=\"p\">}<\/span>\r\n    <span class=\"p\">]<\/span>\r\n  <span class=\"p\">}<\/span>\r\n<span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<p>url\u30d5\u30a3\u30fc\u30eb\u30c9\u3092\u6307\u5b9a\u3057\u306a\u3044\u5834\u5408\u3001\u30e1\u30a4\u30f3\u30a6\u30a3\u30f3\u30c9\u30a6\u3068\u540c\u3058\u30a6\u30a3\u30f3\u30c9\u30a6\u304c\u751f\u6210\u3055\u308c\u307e\u3059\u3002\u57fa\u672c\u7684\u306b\u306f\u3001url\u3092\u6307\u5b9a\u3057\u5225\u30da\u30fc\u30b8\u3092\u4f5c\u308a\u307e\u3059\u3002<\/p>\n<p>\u5225\u30da\u30fc\u30b8\u306e\u4f5c\u6210\u65b9\u6cd5\u306fReact\u7b49\u306e\u5834\u5408\u3061\u3087\u3063\u3068\u8907\u96d1\u306a\u305f\u3081\u5f8c\u8ff0\u3057\u307e\u3059\u3002<\/p>\n<h4>\u52d5\u7684\u306b\u30a6\u30a3\u30f3\u30c9\u30a6\u751f\u6210<\/h4>\n<p>\u3053\u306e\u7bc0\u306f\u30b9\u30da\u30fc\u30b9\u7bc0\u7d04\u306e\u90fd\u5408\u4e0a\u6298\u308a\u305f\u305f\u307f\u307e\u3059\u3002\u7279\u306b\u9762\u767d\u307f\u3082\u306a\u3044\u306e\u3067&#8230;<\/p>\n<details>RustRust<br \/>\n\/\/ omit details<\/p>\n<p>fn main() {<br \/>\ntauri::Builder::default()<br \/>\n.invoke_handler(tauri::generate_handler![get_entries])<\/p>\n<p>.setup(|app| {<br \/>\nlet _sub_window = tauri::WindowBuilder::new(<br \/>\napp,<br \/>\n&#8220;RustSubWindow&#8221;,<br \/>\ntauri::WindowUrl::App(&#8220;sub.html&#8221;.into()),<br \/>\n)<br \/>\n.build()?;<\/p>\n<p>Ok(())<br \/>\n})<\/p>\n<p>.run(tauri::generate_context!())<br \/>\n.expect(&#8220;error while running tauri application&#8221;);<br \/>\n}<\/p>\n<\/details>\n<details>TypeScripttauri.conf.json<br \/>\n{<br \/>\n\/\/ omit details<br \/>\n&#8220;tauri&#8221;: {<br \/>\n&#8220;allowlist&#8221;: {<br \/>\n\/\/ omit details<br \/>\n&#8220;window&#8221;: {<br \/>\n&#8220;all&#8221;: true<br \/>\n}<br \/>\n},<br \/>\n\/\/ omit details<br \/>\n}<br \/>\n}<\/p>\n<p>TypeScript (src\/main.tsx\u30d5\u30a1\u30a4\u30eb)<br \/>\nimport React from &#8220;react&#8221;;<br \/>\nimport ReactDOM from &#8220;react-dom\/client&#8221;;<br \/>\nimport App from &#8220;.\/App&#8221;;<br \/>\nimport &#8220;.\/styles.css&#8221;;<\/p>\n<p>\/\/ \u30a6\u30a3\u30f3\u30c9\u30a6\u751f\u6210<br \/>\nconst webview = new WebviewWindow(&#8220;TSSubWindw&#8221;, { url: &#8220;sub.html&#8221; });<\/p>\n<p>\/\/ \u751f\u6210\u6210\u529f\u6642\u306e\u30b3\u30fc\u30eb\u30d0\u30c3\u30af<br \/>\nwebview.once(&#8220;tauri:\/\/created&#8221;, function () {<br \/>\nconsole.log(&#8220;created&#8221;);<br \/>\n});<\/p>\n<p>\/\/ \u751f\u6210\u5931\u6557\u6642\u306e\u30b3\u30fc\u30eb\u30d0\u30c3\u30af<br \/>\nwebview.once(&#8220;tauri:\/\/error&#8221;, function (e) {<br \/>\nconsole.log(&#8220;error:&#8221;, e);<br \/>\n});<\/p>\n<p>ReactDOM.createRoot(document.getElementById(&#8220;root&#8221;) as HTMLElement).render(<\/p>\n<p>);<\/p>\n<\/details>\n<p>\u4f55\u304b\u3057\u3089\u306e\u51e6\u7406\u3084\u30c7\u30fc\u30bf\u306b\u5bfe\u5fdc\u3057\u305f\u30a6\u30a3\u30f3\u30c9\u30a6\u3092\u4f5c\u6210\u3057\u305f\u3044\u5834\u5408\u306b\u5f79\u7acb\u3061\u305d\u3046\u3067\u3059\u3002<\/p>\n<h4>\u5225\u30da\u30fc\u30b8\u306b\u3064\u3044\u3066<\/h4>\n<p>\u672c\u6a5f\u80fd\u3067\u89e3\u8aac\u3057\u305f\u304b\u3063\u305f\u306e\u306f\u3069\u3061\u3089\u304b\u3068\u3044\u3046\u3068\u3053\u3061\u3089\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p>\u30d0\u30cb\u30e9\u3067\u3042\u3063\u305f\u308a\u3001\u9759\u7684\u306a\u30da\u30fc\u30b8\u3067\u3042\u3063\u305f\u308a\u3068\u3001\u30e2\u30b8\u30e5\u30fc\u30eb\u30d0\u30f3\u30c9\u30e9\u30fc\u3092\u4f7f\u7528\u305b\u305a\u6e08\u3080\u5834\u5408\u306f\u3001\u5358\u306b\u30da\u30fc\u30b8\u3092\u8ffd\u52a0\u3059\u308b\u3060\u3051\u3067\u554f\u984c\u306a\u3044\u306e\u3067\u3059\u304c\u3001\u30d0\u30f3\u30c9\u30eb\u304c\u5fc5\u8981\u306a\u30da\u30fc\u30b8\u306e\u5834\u5408\u3001\u5404\u30d0\u30f3\u30c9\u30e9\u306b\u8a2d\u5b9a\u306e\u8ffd\u8a18\u304c\u5fc5\u8981\u3067\u3059\u3002\u8a18\u4e8b\u4f5c\u6210\u6642\u70b9\u306etauri-cli 1.2.3\u3067\u306f\u30d0\u30f3\u30c9\u30e9\u306bvite\u3092\u4f7f\u7528\u3059\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u308b\u305f\u3081\u3001\u672c\u7bc0\u3067\u306fvite\u3067\u306e\u5834\u5408\u3092\u8aac\u660e\u3057\u307e\u3059\u3002<\/p>\n<p>&#8230;\u3068\u8a00\u3063\u3066\u3082\u305d\u3053\u307e\u3067\u8907\u96d1\u3067\u306f\u306a\u304f\u3001vite.config.ts\u306erollupOptions\u306b\u3066\u4e0b\u8a18\u306e\u3088\u3046\u306b\u8a18\u8ff0\u3059\u308b\u3053\u3068\u3067\u3001\u8907\u6570\u30da\u30fc\u30b8\u306e\u30d0\u30f3\u30c9\u30eb\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002\u7b46\u8005\u3082\u3053\u308c\u4ee5\u4e0a\u306e\u8a73\u7d30\u306f\u73fe\u6642\u70b9\u3067\u7406\u89e3\u3057\u3066\u3044\u306a\u3044\u3067\u3059<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">defineConfig<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">vite<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">react<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">@vitejs\/plugin-react<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<span class=\"hil\"><span class=\"o\">+ <\/span><span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">resolve<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">path<\/span><span class=\"dl\">\"<\/span><span class=\"p\">;<\/span>\r\n<\/span>\r\n<span class=\"c1\">\/\/ omit details<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nf\">defineConfig<\/span><span class=\"p\">(<\/span><span class=\"k\">async <\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">({<\/span>\r\n  <span class=\"c1\">\/\/ omit details<\/span>\r\n  <span class=\"na\">build<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"c1\">\/\/ omit details<\/span>\r\n<span class=\"hil\"><span class=\"o\">+ <\/span>   <span class=\"na\">rollupOptions<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n<\/span><span class=\"hil\"><span class=\"o\">+ <\/span>     <span class=\"na\">input<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n<\/span><span class=\"hil\"><span class=\"o\">+ <\/span>       <span class=\"na\">index<\/span><span class=\"p\">:<\/span> <span class=\"nf\">resolve<\/span><span class=\"p\">(<\/span><span class=\"nx\">__dirname<\/span><span class=\"p\">,<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">index.html<\/span><span class=\"dl\">\"<\/span><span class=\"p\">),<\/span>\r\n<\/span><span class=\"hil\"><span class=\"o\">+ <\/span>       <span class=\"na\">config<\/span><span class=\"p\">:<\/span> <span class=\"nf\">resolve<\/span><span class=\"p\">(<\/span><span class=\"nx\">__dirname<\/span><span class=\"p\">,<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">sub.html<\/span><span class=\"dl\">\"<\/span><span class=\"p\">),<\/span>\r\n<\/span><span class=\"hil\"><span class=\"o\">+ <\/span>     <span class=\"p\">},<\/span>\r\n<\/span><span class=\"hil\"><span class=\"o\">+ <\/span>   <span class=\"p\">},<\/span>\r\n<\/span>  <span class=\"p\">},<\/span>\r\n<span class=\"p\">}));<\/span>\r\n<\/code><\/pre>\n<details>\u30d0\u30f3\u30c9\u30eb\u3055\u308c\u308bsub.html\u306e\u4f8bsub.html<\/p>\n<p>&nbsp;<\/p>\n<div id=\"root\"><\/div>\n<p><script type=\"module\" src=\"\/src\/sub.tsx\"><\/script><\/p>\n<p>src\/sub.tsx<br \/>\nimport React from &#8220;react&#8221;;<br \/>\nimport ReactDOM from &#8220;react-dom\/client&#8221;;<\/p>\n<p>ReactDOM.createRoot(document.getElementById(&#8220;root&#8221;) as HTMLElement).render(<\/p>\n<p>&lt;&gt;Bundled Sub Page&lt;\/&gt;<\/p>\n<p>);<\/p>\n<\/details>\n<p>\u4f53\u611f\u3067\u3059\u304c\u3001\u3082\u3057\u304b\u3057\u305f\u3089Tauri\u81ea\u4f53\u306e\u30de\u30eb\u30c1\u30a6\u30a3\u30f3\u30c9\u30a6\u8a2d\u5b9a\u3088\u308a\u3082\u30d0\u30f3\u30c9\u30e9\u3054\u3068\u306e\u3053\u3046\u3044\u3063\u305f\u8a2d\u5b9a\u306e\u65b9\u6cd5\u306e\u65b9\u304c\u691c\u7d22\u3067\u898b\u3064\u3051\u306b\u304f\u3044\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002<\/p>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Multiwindow | Tauri Apps<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u3010Vite\u3011\u8907\u6570\u30da\u30fc\u30b8\u3042\u308b\u5834\u5408\u306e\u8a2d\u5b9a\u3092\u8003\u3048\u308b &#8211; UGA Boxxx<\/ul>\n<h3>\u30a2\u30a4\u30b3\u30f3\u751f\u6210\u3068\u81ea\u52d5\u53cd\u6620\u306e\u753b\u7adc\u70b9\u775b<\/h3>\n<p>GUI\u30a2\u30d7\u30ea\u306f\u72ec\u81ea\u306e\u30a2\u30a4\u30b3\u30f3\u3001\u72ec\u81ea\u306e\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u304c\u3042\u3063\u3066\u3053\u305d\u5b8c\u6210\u3057\u307e\u3059\uff01\u3088\u306d&#8230;?<\/p>\n<p>\u3068\u306f\u3044\u3048\u3001\u30bf\u30b9\u30af\u30d0\u30fc\u7528\u306e\u30a2\u30a4\u30b3\u30f3\u3001\u30b7\u30b9\u30c6\u30e0\u30c8\u30ec\u30a4\u7528\u306e\u30a2\u30a4\u30b3\u30f3\u3001\u30a6\u30a3\u30f3\u30c9\u30a6\u5de6\u4e0a\u306e\u30a2\u30a4\u30b3\u30f3\u3001\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u306e\u30a2\u30a4\u30b3\u30f3\u3001\u3001\u3001\u3068\u3001\u8a2d\u5b9a\u3057\u306a\u3051\u308c\u3070\u306a\u3089\u306a\u3044\u5bfe\u8c61\u306f\u591a\u304f\u3001\u30b5\u30a4\u30ba\u3082\u8272\u3005\u7528\u610f\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u305d\u3046\u3067\u3059\u3002<\/p>\n<p>\u305d\u3093\u306a\u3042\u306a\u305f\u306e\u9858\u671b\u306b\u5fdc\u3048\u3001Tauri\u306b\u306f\u5404\u7a2e\u30a2\u30a4\u30b3\u30f3\u30921\u679a\u306e\u753b\u50cf\u304b\u3089\u8a2d\u5b9a\u3059\u308bCLI\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u304c\u5185\u5305\u3055\u308c\u3066\u3044\u307e\u3059\u3002\u4f8b\u3048\u3070image.png\u3068\u3044\u3046\u753b\u50cf\u3092\u30a2\u30a4\u30b3\u30f3\u306b\u3057\u305f\u3044\u5834\u5408\u3001\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3092\u6253\u3064\u3060\u3051\u3067\u8a2d\u5b9a\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"err\">&gt;<\/span> <span class=\"n\">yarn<\/span> <span class=\"nx\">tauri<\/span> <span class=\"nx\">icon<\/span> <span class=\"nx\">image.png<\/span>\r\n<\/code><\/pre>\n<div>\n<p>\u30a2\u30a4\u30b3\u30f3\u3092\u5909\u66f4\u3057\u305f\u3044\u5834\u5408\u306f\u307e\u305f\u4e0a\u8a18\u30b3\u30de\u30f3\u30c9\u3092\u6253\u3066\u3070\u826f\u3044\u306e\u3067\u3059\u304c\u3001Windows\u306e\u5834\u5408\u3060\u3068\u30b7\u30e7\u30fc\u30c8\u30ab\u30c3\u30c8\u30a2\u30a4\u30b3\u30f3\u306e\u307f\u5909\u66f4\u3055\u308c\u306a\u3044\u6642\u304c\u3042\u308a\u307e\u3059\u3002<br \/>\n\u305d\u306e\u3088\u3046\u306a\u5834\u5408\u306f\u4e00\u5ea6target\u30d5\u30a9\u30eb\u30c0\u3054\u3068\u3075\u3063\u98db\u3070\u3057\u3066\u30d3\u30eb\u30c9\u3057\u76f4\u3059\u3068\u5909\u66f4\u3055\u308c\u307e\u30598\u3002<\/p>\n<\/div>\n<p>\u30a2\u30a4\u30b3\u30f3\u304c\u6c7a\u307e\u308b\u3068\u4e00\u6c17\u306b\u30a2\u30d7\u30ea\u304c\u5b8c\u6210\u3057\u305f\u611f\u304c\u51fa\u307e\u3059\u306d\uff01<\/p>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">Icons | Tauri Apps<\/ul>\n<h3>\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u3068GitHubActions\u306e\u30c7\u30d7\u30ed\u30a4\u9769\u547d<\/h3>\n<p>\u7686\u3055\u3093\u306f\u5b8c\u6210\u3057\u305f\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u3069\u306e\u3088\u3046\u306b\u914d\u5e03\u3057\u3066\u3044\u307e\u3059\u304b&#8230;\uff1fzip\u306b\u5727\u7e2e\u3057\u305f\u308a\u4f7f\u7528\u8005\u306bGitHub\u304b\u3089\u30af\u30ed\u30fc\u30f3\u3057\u3066\u624b\u5143\u3067\u30d3\u30eb\u30c9\u3057\u3066\u3082\u3089\u3046\u306a\u3069\u3067\u3057\u3087\u3046\u304b&#8230;\uff1f\u6298\u89d2\u30a2\u30d7\u30ea\u3092\u4f5c\u3063\u3066\u3082\/\u4f5c\u308a\u305f\u304f\u3066\u3082\u5c0e\u5165\u3057\u306b\u304f\u3044\u3068\u30e2\u30c1\u30d9\u306b\u5f71\u97ff\u3057\u305d\u3046\u3067\u3059\u3002<\/p>\n<p>\u3067\u3082\u5b89\u5fc3\u3057\u3066\u304f\u3060\u3055\u3044\u3002Tauri\u306f\u914d\u5e03\u3059\u308b\u624b\u6bb5\u306e\u4e2d\u3067\u306f\u4e00\u756a\u697d\u306a\u3001\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u3092\u751f\u6210\u3057\u3066\u304f\u308c\u307e\u3059\u3002yarn tauri dev\u3067\u306f\u306a\u304f\u3001yarn tauri build\u30b3\u30de\u30f3\u30c9\u3092\u6253\u3064\u3060\u3051\u3067\u3001\u4f8b\u3048\u3070Windows\u5411\u3051\u306a\u3089\u3070src-tauri &gt; target &gt; release &gt; bundle &gt; msi\u4ee5\u4e0b\u306b\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u304c\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"err\">&gt;<\/span> <span class=\"n\">yarn<\/span> <span class=\"nx\">tauri<\/span> <span class=\"nx\">build<\/span>\r\n<span class=\"o\">...<\/span>\r\n<span class=\"err\">&gt;<\/span> <span class=\"n\">ls<\/span> <span class=\"nx\">src-tauri\/target\/release\/bundle\/msi<\/span>\r\n\r\n    <span class=\"err\">\u30c7\u30a3\u30ec\u30af\u30c8\u30ea<\/span><span class=\"p\">:<\/span> <span class=\"n\">C:\\path\\to\\tauri-react-player\\src-tauri\\target\\release\\bundle\\msi<\/span>\r\n\r\n<span class=\"n\">Mode<\/span>                 <span class=\"nx\">LastWriteTime<\/span>         <span class=\"nx\">Length<\/span> <span class=\"nx\">Name<\/span>\r\n<span class=\"o\">----<\/span>                 <span class=\"o\">-------------<\/span>         <span class=\"o\">------<\/span> <span class=\"o\">----<\/span>\r\n<span class=\"nt\">-a<\/span><span class=\"o\">----<\/span>        <span class=\"mi\">2023<\/span><span class=\"n\">\/03\/22<\/span>      <span class=\"nx\">0:35<\/span>        <span class=\"nx\">2404352<\/span> <span class=\"nx\">tauri-react-player_0.0.0_x64_en-US.msi<\/span>\r\n<\/code><\/pre>\n<div>\n<p>\u3061\u306a\u307f\u306b\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u3092\u4f7f\u3046\u3068WebView2\u3082\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u308b\u305f\u3081\u3001 Windows10\u3067\u3082\u52d5\u304d\u307e\u3059 \uff01<\/p>\n<\/div>\n<p>\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u3068\u305d\u306e\u30c1\u30a7\u30c3\u30af\u30b5\u30e0\u3092\u914d\u5e03\u30b5\u30a4\u30c8\u306b\u7f6e\u3044\u3066\u304a\u304f\u306e\u3082\u826f\u3044\u3067\u3059\u304c\u3001Tauri\u516c\u5f0f\u304c\u63d0\u4f9b\u3059\u308bGitHub Actions\u3092\u4f7f\u3046\u3068\u30a4\u30f3\u30b9\u30c8\u30fc\u30e9\u3092GitHub\u5074\u3067\u4f5c\u6210\u3057\u3055\u3089\u306b\u30ea\u30ea\u30fc\u30b9\u30da\u30fc\u30b8\u3067\u914d\u5e03\u307e\u3067\u3067\u304d\u307e\u3059\uff01\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u306e\u6539\u3056\u3093\u306f\u53b3\u3057\u305d\u3046\u3067\u3059\u3057\u3001GitHub\u306b\u516c\u958b\u3057\u305f\u30b3\u30fc\u30c9\u305d\u306e\u307e\u307e\u3067\u30d3\u30eb\u30c9\u3055\u308c\u308b\u306e\u3067\u3001\u30c1\u30a7\u30c3\u30af\u30b5\u30e0\u3092\u4f7f\u3063\u305f\u914d\u5e03\u3088\u308a\u3082\u4fe1\u983c\u3067\u304d\u308b\u914d\u5e03\u65b9\u6cd5\u3068\u8a00\u3048\u308b\u3067\u3057\u3087\u3046\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u516c\u5f0f\u306b\u63b2\u8f09\u3055\u308c\u3066\u3044\u308b\u4f8b\u3067\u306f\u3001release\u30d6\u30e9\u30f3\u30c1\u30d7\u30c3\u30b7\u30e5\u6642\u306b\u30ea\u30ea\u30fc\u30b9Draft\u3092\u4f5c\u6210\u3059\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>.github &gt; workflows\u306b\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u30d5\u30a1\u30a4\u30eb\u3092\u7f6e\u304d\u30d7\u30c3\u30b7\u30e5\u3059\u308b\u3053\u3068\u3067\u3001\u6761\u4ef6\u304c\u63c3\u3048\u3070(\u4f8b\u3067\u306frelease\u306b\u30d7\u30c3\u30b7\u30e5\u3055\u308c\u308c\u3070)\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u304c\u8d70\u308a\u307e\u3059\u3002\u4ee5\u4e0b\u306f\u30ab\u30b9\u30bf\u30e0\u3067\u89e6\u308b\u3053\u3068\u304c\u3042\u308b\u304b\u3082\u3057\u308c\u306a\u3044\u9805\u76ee\u3067\u3059\u3002<\/p>\n<div>\n<div class=\"post-table\">\u9805\u76ee\u5185\u5bb9on &gt; push<code>tags<\/code>\u3067\u30bf\u30b0\u3092\u6307\u5b9a\u3057\u305f\u308a\u3001<code>branches<\/code>\u3092<code>release<\/code>\u3067\u306f\u306a\u304f\u76f4\u63a5<code>main<\/code>\u306b\u3057\u305f\u308a\u7b49&#8230; &gt; matrix &gt; platform\u30af\u30ed\u30b9\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u306b\u95a2\u3059\u308b\u9805\u76ee\u3067\u3059\u304c\u3001\u4f8b\u3048\u3070Windows\u5411\u3051\u306b\u3057\u304b\u4f5c\u3063\u3066\u3044\u306a\u3044\u5834\u5408\u306f\u3053\u3053\u3092\u6e1b\u3089\u3057\u307e\u3059\u3002<br \/>\n\u4f34\u3044\u3001<code>ubuntu only<\/code>\u3068\u306a\u3063\u3066\u3044\u308b\u9805\u76ee\u3092\u6d88\u3057\u305f\u308a\u3059\u308b\u3053\u3068\u3082\u3042\u308a\u305d\u3046\u3067\u3059\u3002actions\/setup-node@v3\u306ewith &gt; node-versionnode\u30d0\u30fc\u30b8\u30e7\u30f3\u306f\u624b\u5143\u306e\u3082\u306e\u306b\u5408\u308f\u305b\u307e\u3057\u3087\u3046\u3002<\/div>\n<\/div>\n<pre class=\"post-pre\"><code><span class=\"na\">name<\/span><span class=\"pi\">:<\/span> <span class=\"s1\">'<\/span><span class=\"s\">publish'<\/span>\r\n<span class=\"na\">on<\/span><span class=\"pi\">:<\/span>\r\n  <span class=\"na\">push<\/span><span class=\"pi\">:<\/span>\r\n    <span class=\"na\">branches<\/span><span class=\"pi\">:<\/span>\r\n      <span class=\"pi\">-<\/span> <span class=\"s\">release<\/span>\r\n\r\n<span class=\"na\">jobs<\/span><span class=\"pi\">:<\/span>\r\n  <span class=\"na\">publish-tauri<\/span><span class=\"pi\">:<\/span>\r\n    <span class=\"na\">permissions<\/span><span class=\"pi\">:<\/span>\r\n      <span class=\"na\">contents<\/span><span class=\"pi\">:<\/span> <span class=\"s\">write<\/span>\r\n    <span class=\"na\">strategy<\/span><span class=\"pi\">:<\/span>\r\n      <span class=\"na\">fail-fast<\/span><span class=\"pi\">:<\/span> <span class=\"kc\">false<\/span>\r\n      <span class=\"na\">matrix<\/span><span class=\"pi\">:<\/span>\r\n        <span class=\"na\">platform<\/span><span class=\"pi\">:<\/span> <span class=\"pi\">[<\/span><span class=\"nv\">macos-latest<\/span><span class=\"pi\">,<\/span> <span class=\"nv\">ubuntu-20.04<\/span><span class=\"pi\">,<\/span> <span class=\"nv\">windows-latest<\/span><span class=\"pi\">]<\/span>\r\n\r\n    <span class=\"na\">runs-on<\/span><span class=\"pi\">:<\/span> <span class=\"s\">${{ matrix.platform }}<\/span>\r\n    <span class=\"na\">steps<\/span><span class=\"pi\">:<\/span>\r\n      <span class=\"pi\">-<\/span> <span class=\"na\">uses<\/span><span class=\"pi\">:<\/span> <span class=\"s\">actions\/checkout@v3<\/span>\r\n      <span class=\"pi\">-<\/span> <span class=\"na\">name<\/span><span class=\"pi\">:<\/span> <span class=\"s\">setup node<\/span>\r\n        <span class=\"na\">uses<\/span><span class=\"pi\">:<\/span> <span class=\"s\">actions\/setup-node@v3<\/span>\r\n        <span class=\"na\">with<\/span><span class=\"pi\">:<\/span>\r\n          <span class=\"na\">node-version<\/span><span class=\"pi\">:<\/span> <span class=\"m\">16<\/span>\r\n      <span class=\"pi\">-<\/span> <span class=\"na\">name<\/span><span class=\"pi\">:<\/span> <span class=\"s\">install Rust stable<\/span>\r\n        <span class=\"na\">uses<\/span><span class=\"pi\">:<\/span> <span class=\"s\">dtolnay\/rust-toolchain@stable<\/span>\r\n      <span class=\"pi\">-<\/span> <span class=\"na\">name<\/span><span class=\"pi\">:<\/span> <span class=\"s\">install dependencies (ubuntu only)<\/span>\r\n        <span class=\"na\">if<\/span><span class=\"pi\">:<\/span> <span class=\"s\">matrix.platform == 'ubuntu-20.04'<\/span>\r\n        <span class=\"na\">run<\/span><span class=\"pi\">:<\/span> <span class=\"pi\">|<\/span>\r\n          <span class=\"s\">sudo apt-get update<\/span>\r\n          <span class=\"s\">sudo apt-get install -y libgtk-3-dev libwebkit2gtk-4.0-dev libappindicator3-dev librsvg2-dev patchelf<\/span>\r\n      <span class=\"pi\">-<\/span> <span class=\"na\">name<\/span><span class=\"pi\">:<\/span> <span class=\"s\">install frontend dependencies<\/span>\r\n        <span class=\"na\">run<\/span><span class=\"pi\">:<\/span> <span class=\"s\">yarn install<\/span> <span class=\"c1\"># change this to npm or pnpm depending on which one you use<\/span>\r\n      <span class=\"pi\">-<\/span> <span class=\"na\">uses<\/span><span class=\"pi\">:<\/span> <span class=\"s\">tauri-apps\/tauri-action@v0<\/span>\r\n        <span class=\"na\">env<\/span><span class=\"pi\">:<\/span>\r\n          <span class=\"na\">GITHUB_TOKEN<\/span><span class=\"pi\">:<\/span> <span class=\"s\">${{ secrets.GITHUB_TOKEN }}<\/span>\r\n        <span class=\"na\">with<\/span><span class=\"pi\">:<\/span>\r\n          <span class=\"na\">tagName<\/span><span class=\"pi\">:<\/span> <span class=\"s\">app-v__VERSION__<\/span> <span class=\"c1\"># the action automatically replaces \\_\\_VERSION\\_\\_ with the app version<\/span>\r\n          <span class=\"na\">releaseName<\/span><span class=\"pi\">:<\/span> <span class=\"s1\">'<\/span><span class=\"s\">App<\/span> <span class=\"s\">v__VERSION__'<\/span>\r\n          <span class=\"na\">releaseBody<\/span><span class=\"pi\">:<\/span> <span class=\"s1\">'<\/span><span class=\"s\">See<\/span> <span class=\"s\">the<\/span> <span class=\"s\">assets<\/span> <span class=\"s\">to<\/span> <span class=\"s\">download<\/span> <span class=\"s\">this<\/span> <span class=\"s\">version<\/span> <span class=\"s\">and<\/span> <span class=\"s\">install.'<\/span>\r\n          <span class=\"na\">releaseDraft<\/span><span class=\"pi\">:<\/span> <span class=\"kc\">true<\/span>\r\n          <span class=\"na\">prerelease<\/span><span class=\"pi\">:<\/span> <span class=\"kc\">false<\/span>\r\n<\/code><\/pre>\n<p>node-version\u306e\u307f\u4fee\u6b63\u3057\u5b9f\u969b\u306b\u8d70\u3089\u305b\u3066\u307f\u307e\u3057\u305f\u3002<\/p>\n<details>\u4fee\u6b63\u70b9\u5dee\u5206.github\/workflows\/build.yaml<br \/>\nname: &#8216;publish&#8217;<br \/>\non:<br \/>\npush:<br \/>\nbranches:<br \/>\n&#8211; release<\/p>\n<p>jobs:<br \/>\npublish-tauri:<br \/>\npermissions:<br \/>\ncontents: write<br \/>\nstrategy:<br \/>\nfail-fast: false<br \/>\nmatrix:<br \/>\nplatform: [macos-latest, ubuntu-20.04, windows-latest]<\/p>\n<p>runs-on: ${{ matrix.platform }}<br \/>\nsteps:<br \/>\n&#8211; uses: actions\/checkout@v3<br \/>\n&#8211; name: setup node<br \/>\nuses: actions\/setup-node@v3<br \/>\nwith:<br \/>\n&#8211; node-version: 16<br \/>\n+ node-version: 18<br \/>\n&#8211; name: install Rust stable<br \/>\nuses: dtolnay\/rust-toolchain@stable<br \/>\n&#8211; name: install dependencies (ubuntu only)<br \/>\nif: matrix.platform == &#8216;ubuntu-20.04&#8217;<br \/>\nrun: |<br \/>\nsudo apt-get update<br \/>\nsudo apt-get install -y libgtk-3-dev libwebkit2gtk-4.0-dev libappindicator3-dev librsvg2-dev patchelf<br \/>\n&#8211; name: install frontend dependencies<br \/>\nrun: yarn install # change this to npm or pnpm depending on which one you use<br \/>\n&#8211; uses: tauri-apps\/tauri-action@v0<br \/>\nenv:<br \/>\nGITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}<br \/>\nwith:<br \/>\ntagName: app-v__VERSION__ # the action automatically replaces \\_\\_VERSION\\_\\_ with the app version<br \/>\nreleaseName: &#8216;App v__VERSION__&#8217;<br \/>\nreleaseBody: &#8216;See the assets to download this version and install.&#8217;<br \/>\nreleaseDraft: true<br \/>\nprerelease: false<\/p>\n<\/details>\n<pre class=\"post-pre\"><code><span class=\"err\">&gt;<\/span> <span class=\"n\">git<\/span> <span class=\"nx\">branch<\/span>\r\n  <span class=\"n\">main<\/span>\r\n<span class=\"o\">*<\/span> <span class=\"nx\">release<\/span>\r\n<span class=\"err\">&gt;<\/span> <span class=\"n\">git<\/span> <span class=\"nx\">add<\/span> <span class=\"nt\">-A<\/span>\r\n<span class=\"err\">&gt;<\/span> <span class=\"n\">git<\/span> <span class=\"nx\">commit<\/span> <span class=\"nt\">-m<\/span> <span class=\"s2\">\"v0.0.1\"<\/span>\r\n<span class=\"err\">&gt;<\/span> <span class=\"n\">git<\/span> <span class=\"nx\">push<\/span> <span class=\"nx\">origin<\/span> <span class=\"nx\">release<\/span>\r\n<\/code><\/pre>\n<p>\u30d7\u30c3\u30b7\u30e5\u5f8c\u306b\u30ea\u30dd\u30b8\u30c8\u30ea\u306eActions\u30da\u30fc\u30b8 (\u4f8b) \u306b\u98db\u3076\u3068\u3001\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u304c\u5b9f\u884c\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u304c\u78ba\u8a8d\u3067\u304d\u307e\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/240-0.png\" alt=\"image.png\" \/><\/div>\n<div>\n<p>Error: Resource not accessible by integration\u3068\u3044\u3046\u30a8\u30e9\u30fc\u304c\u51fa\u308b\u3053\u3068\u304c\u3042\u308a\u307e\u3059\u3002<br \/>\n\u518d\u73fe\u6761\u4ef6\u304c\u7279\u5b9a\u3067\u304d\u306a\u304b\u3063\u305f\u306e\u3067\u3059\u304c\u3001\u3053\u306e\u30a8\u30e9\u30fc\u304c\u51fa\u305f\u969b\u306f<br \/>\nSettings &gt; Actions &gt; General &gt; Workflow permissions<br \/>\n\u3092\u3001Read and write permissions\u306b\u5909\u66f4\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<br \/>\n\u53c2\u8003: Github Actions\u3067Resource not accessible by integration\u304c\u51fa\u305f\u969b\u306e\u5bfe\u51e6\u6cd5<\/p>\n<\/div>\n<p>\u6210\u529f\u3059\u308b\u3068\u3053\u3093\u306a\u611f\u3058\u3067\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/243-0.png\" alt=\"image.png\" \/><\/div>\n<p>\u4f5c\u6210\u3055\u308c\u305fDraft\u304b\u3089\u30ea\u30ea\u30fc\u30b9\u3092\u4f5c\u6210\u3059\u308c\u3070\u30c7\u30d7\u30ed\u30a4\u5b8c\u4e86\u3067\u3059\u3002<\/p>\n<p>\u30ea\u30dd\u30b8\u30c8\u30ea\u306e\u30c8\u30c3\u30d7\u30da\u30fc\u30b8\u53f3\u306bReleases\u3068\u3044\u3046\u9805\u76ee\u304c\u3042\u308a\u307e\u3059\u3002\u3053\u3053\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u30ea\u30ea\u30fc\u30b9\u4e00\u89a7\u306b\u98db\u3079\u307e\u3059\u3002<\/p>\n<p>\u3059\u308b\u3068\u5148\u7a0b\u4f5c\u6210\u3057\u305fDraft\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/247-0.png\" alt=\"\u30ea\u30ea\u30fc\u30b9\u30c9\u30e9\u30d5\u30c8.png\" \/><\/div>\n<p>\u304b\u3089\u7de8\u96c6\u30da\u30fc\u30b8\u306b\u98db\u3073\u3001\u4e00\u756a\u4e0b\u7dd1\u8272\u306ePublish release\u3092\u62bc\u3059\u3053\u3068\u3067\u30ea\u30ea\u30fc\u30b9\u304c\u4f5c\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/249-0.png\" alt=\"image.png\" \/><\/div>\n<p>\u30ea\u30ea\u30fc\u30b9\u304c\u751f\u6210\u3055\u308c\u308b\u3068\u30ea\u30dd\u30b8\u30c8\u30ea\u306e\u30c8\u30c3\u30d7\u30da\u30fc\u30b8\u53f3\u306b\u6700\u65b0\u30ea\u30ea\u30fc\u30b9\u3078\u306e\u30ea\u30f3\u30af\u304c\u51fa\u6765\u307e\u3059\u3002\u30ab\u30c3\u30b3\u3044\u3044\u30ea\u30ea\u30fc\u30b9\u304c\u51fa\u6765\u307e\u3057\u305f\uff01<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/251-0.png\" alt=\"image.png\" \/><\/div>\n<p>\u53c2\u8003<\/p>\n<ul class=\"post-ul\">tauri-apps\/tauri-action: Build your Web application as a Tauri binary for MacOS, Linux and Windows<\/ul>\n<h1>\u307e\u3068\u3081\u30fb\u6240\u611f<\/h1>\n<p>\u3053\u3053\u6570\u30f6\u6708Tauri\u3092\u89e6\u3063\u305f\u6280\u8853\u7684\u306a\u611f\u60f3\u306f\u3001\u300c\u8a00\u8a9e\u306f\u624b\u6bb5\u3068\u3057\u3066\u6349\u3048\u9069\u6750\u9069\u6240\u3067\u66ff\u3048\u305f\u65b9\u304c\u7d50\u5c40\u697d\u3057\u3044\u300d\u3068\u3044\u3046\u3082\u306e\u3067\u3057\u305f\u3002<\/p>\n<p>\u5c11\u3057\u524d\u306e\u81ea\u5206\u3067\u3042\u308c\u3070\u3001\u899a\u3048\u305f\u3066\u306e\u8a00\u8a9e\u3092\u6fc0\u63a8\u3057\u3057\u3066\u3001\u300c\u305d\u308c\u3007\u3007\u3067\u3082\u3067\u304d\u307e\u3059\uff01\u300d\u3068\u3001\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u4e0d\u5341\u5206\u3060\u308d\u3046\u3068\u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u4ed6\u306e\u8a00\u8a9e\u306e\u30e9\u30c3\u30d1\u30fc\u3057\u304b\u306a\u304b\u308d\u3046\u3068\u7121\u7406\u3084\u308a\u305d\u306e\u8a00\u8a9e\u3092\u4f7f\u3063\u3066\u4f55\u304b\u3092\u4f5c\u308b\u3053\u3068\u306b\u559c\u3073\u3092\u899a\u3048\u3066\u3044\u307e\u3057\u305f\u3002<\/p>\n<p>\u305d\u3093\u306a\u6298\u3001Rust\u3068TypeScript\u306e\u4e21\u65b9\u3092\u66f8\u3044\u3066\u5206\u304b\u3063\u305f\u306e\u306f\u3001\u300c\u6587\u6cd5\u3084\u5f37\u307f\u304c\u9055\u3063\u3066\u3082&#8221;\u4fa1\u5024\u89b3&#8221;9\u304c\u540c\u3058\u8a00\u8a9e\u305f\u3061\u304c\u3044\u308b\u300d\u3068\u3044\u3046\u3053\u3068\u3067\u3057\u305f\u3002<\/p>\n<p>\u3080\u3057\u308d\u3001\u3042\u308b\u8a00\u8a9e\u3067\u5b66\u3093\u3060\u8003\u3048\u304c\u4ed6\u306e\u8a00\u8a9e\u3092\u5b66\u3093\u3060\u6642\u306b\u51fa\u3066\u304d\u305f\u6642\u306e\u307b\u3046\u304c\u5b09\u3057\u3044\u306e\u3067\u3059\u3002Rust\u3068TypeScript\u306f\u5bfe\u7167\u7684\u306a2\u4eba\u3068\u8a00\u3063\u305f\u306e\u3067\u3059\u304c\u3001\u578b\u7406\u8ad6\u3084\u95a2\u6570\u578b\u30d1\u30e9\u30c0\u30a4\u30e0\u306a\u3069\u3001\u30e2\u30c0\u30f3\u8a00\u8a9e\u306b\u3042\u308b\u3068\u5b09\u3057\u3044\u3088\u3046\u306a\u5171\u901a\u70b9\u3082\u591a\u3005\u3042\u308a\u307e\u3059\u3002\u307e\u308b\u3067\u307c\u3063\u3061\u3061\u3083\u3093\u3082\u559c\u591a\u3061\u3083\u3093\u3082\u300c\u5909\u308f\u308a\u305f\u3044\u300d\u3068\u3044\u3046\u6c17\u6301\u3061\u3092\u304d\u3063\u304b\u3051\u306b\u30ae\u30bf\u30fc\u3092\u63e1\u3063\u305f\u307f\u305f\u3044\u3067\u3059\u306d\u3002<\/p>\n<p>\u4e00\u3064\u306e\u8a00\u8a9e\u3060\u3051\u306b\u3053\u3060\u308f\u3063\u3066\u3044\u308b\u9650\u308a\u6c7a\u3057\u3066\u77e5\u308b\u3053\u3068\u304c\u3067\u304d\u306a\u3044&#8230;\u8272\u3005\u306a\u8a00\u8a9e\u3092\u77e5\u308b\u3053\u3068\u3067\u898b\u3048\u308b\u666f\u8272\u304c\u3042\u3063\u305f\u306e\u3067\u3059\u3002<br \/>\n\u305d\u3057\u3066\u3001Tauri\u3092\u4f7f\u3063\u305f\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u306f\u3001Rust\u3068TypeScript\u305d\u308c\u305e\u308c\u306e\u5f37\u307f\u3092\u3088\u308a\u5f37\u8abf\u3057\u3001\u8a00\u8a9e\u3092\u8d85\u3048\u305f\u826f\u3044\u30d1\u30e9\u30c0\u30a4\u30e0\u306e\u5b58\u5728\u3092\u6559\u3048\u3066\u304f\u308c\u308b&#8230;\u305d\u3093\u306a\u666f\u8272\u3092\u898b\u305b\u3066\u304f\u308c\u308b\u767e\u5408\u4f5c\u54c1\u306a\u306e\u3067\u3057\u305f\u3002<\/p>\n<p>\u7b46\u8005\u306e1\u756a\u63a8\u3057\u306fTypeScript\u00d7Rust10\u3067\u3059\u304c\u3001\u3053\u306e\u8003\u3048\u65b9\u306f\u5225\u306a&#8221;\u30ab\u30d7&#8221;\u3067\u3082\u6d41\u7528\u3067\u304d\u308b\u3093\u3058\u3083\u306a\u3044\u304b\u3068\u4e88\u60f3\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u8aad\u8005\u306e\u65b9\u3082\u305c\u3072\u4e00\u63a8\u3057\u306e\u30ab\u30d7\u3092\u63a2\u3057\u3066\u307f\u307e\u3057\u3087\u3046\uff01\u3053\u3053\u307e\u3067\u8aad\u3093\u3067\u3044\u305f\u3060\u304d\u3042\u308a\u304c\u3068\u3046\u3054\u3056\u3044\u307e\u3057\u305f\u3002<\/p>\n<h1>\u305d\u306e\u4ed6 \u53c2\u8003\u30fb\u5f15\u7528<\/h1>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Rust\u5411\u3051GUI\u30c4\u30fc\u30eb\u30ad\u30c3\u30c8\u300cKAS\u300d\u306e\u4f5c\u8005\u304c\u3001Rust\u306eGUI\u5bfe\u5fdc\u72b6\u6cc1\u3092\u632f\u308a\u8fd4\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Rust: state of GUI, December 2022<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Rust GUI \u306e\u6c7a\u5b9a\u7248\uff01 Tauri \u3092\u4f7f\u3063\u3066\u30af\u30ed\u30b9\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u306a\u30c7\u30b9\u30af\u30c8\u30c3\u30d7\u30a2\u30d7\u30ea\u3092\u4f5c\u308d\u3046<\/ul>\n<section>TypeScript\u3067\u306f\u306a\u304fJavaScript\u3084AltJS\u3068\u3057\u3066Rust(with Yew)\u3092\u6307\u5b9a\u3059\u308b\u3053\u3068\u3082\u53ef\u80fd\u3067\u3059\u304c\u3001\u672c\u8a18\u4e8b\u3067\u306fTypeScript with React\u3067\u7d71\u4e00\u3057\u307e\u3059\u3002\u597d\u304d\u306a\u306e\u3067\u3002 \u21a9<\/p>\n<p>\u8ee2\u5929\u3001\u8a18\u4e8b\u57f7\u7b46\u304c\u601d\u3063\u305f\u3088\u308a\u9577\u5f15\u3044\u3066\u6295\u7a3f\u304c\u6700\u7d42\u56de\u653e\u6620\u5f8c\u306b\u306a\u3063\u3066\u3057\u307e\u3044\u307e\u3057\u305f(\u6d99) \u6700\u7d42\u56de\u6700\u9ad8\u3067\u3057\u305f(\u6d992) \u307e\u3060\u89b3\u305f\u3053\u3068\u304c\u306a\u3044\u65b9\u306f\u6709\u6599\u3067\u3059\u304cd\u30a2\u30cb\u3067\u914d\u4fe1\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u305d\u3053\u304b\u3089\u89b3\u307e\u3057\u3087\u3046\u3002 \u21a9<\/p>\n<p>Dioxus\u3068\u3044\u3046GUI\u30e9\u30a4\u30d6\u30e9\u30ea\u3082\u6700\u8fd1\u51fa\u305f\u3088\u3046\u3067\u3059\u304c\u3001\u3088\u304f\u8abf\u3079\u308b\u3068\u3053\u308c\u306fTauri\u30d9\u30fc\u30b9\u3089\u3057\u3044\u306e\u3067\u5019\u88dc\u304b\u3089\u5916\u3057\u307e\u3057\u305f\u3002\u306a\u304a\u3001Bevy\u3084nannou\u3001Amethyst\u3068\u3044\u3063\u305f\u30b2\u30fc\u30e0\u7528\u63cf\u753b\u30a8\u30f3\u30b8\u30f3\u3082\u5916\u3057\u3066\u3044\u307e\u3059\u3002 \u21a9<\/p>\n<p>\u546a\u6587\u306f2 girls, sisters, flat chest, steampunk, overcoat, programming, computer\u3067\u3059\u3002\u5510\u7a81\u306b\u3053\u306e\u633f\u7d75\u3092\u5165\u308c\u305f\u306e\u306f\u30c8\u30ec\u30f3\u30c9\u304cChatGPT\u306b\u5360\u9818\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u306a\u3093\u304b\u5bfe\u6297\u3057\u305f\u304f\u306a\u3063\u305f\u304b\u3089\u3067\u3059(\u5358\u7d14)\u3002\u8ab2\u91d1\u3057\u305f\u4e0a\u3067\u30d7\u30ed\u30f3\u30d7\u30c8\u30a8\u30f3\u30b8\u30cb\u30a2\u3084\u3063\u3066\u307f\u3066\u601d\u3063\u305f\u306e\u3067\u3059\u304c\u671b\u307f\u3069\u304a\u308a\u306e\u7d75\u3092\u63cf\u3051\u308b\u3068\u3044\u3046\u80fd\u529b\u306f\u4eca\u5f8c\u3082\u3057\u3070\u3089\u304fAI\u306b\u53d6\u3063\u3066\u4ee3\u308f\u3089\u308c\u306a\u3044\u6c17\u304c\u3057\u307e\u3059&#8230;\u6642\u306bRust\u3068TypeScript\u304c\u30da\u30a2\u30d7\u30ed\u3059\u308b\u8a71\u7d50\u69cb\u771f\u9762\u76ee\u306b\u8aad\u307f\u305f\u3044\u306e\u3067\u4eca\u5ea6ChatGPT\u306b\u3067\u3082\u66f8\u304b\u305b\u307e\u3059\u304b\u306d \u21a9<\/p>\n<p>\u306a\u3044\u3060\u308d\u3046\u3068\u601d\u3063\u3066\u3044\u305f\u3089\u5b9f\u306f\u65e2\u5b58\u30a2\u30d7\u30ea\u3042\u3063\u305f\u307f\u305f\u3044\u306a\u30d1\u30bf\u30fc\u30f3\u3060\u3063\u305f\u3068\u3057\u3066\u3082\u7279\u306b\u9a5a\u304d\u306f\u3057\u306a\u3044\u306e\u3067\u3001\u3082\u3057\u985e\u4f3c\u306e\u30a2\u30d7\u30ea\u3092\u3054\u5b58\u3058\u306e\u65b9\u304a\u308a\u307e\u3057\u305f\u3089\u30b3\u30e1\u30f3\u30c8\u3067\u6559\u3048\u3066\u3044\u305f\u3060\u3051\u308b\u3068\u5e78\u3044\u3067\u3059(\u3084\u3063\u3071\u308a\u6c17\u306b\u306a\u308b\u306e\u3067)\u3002 \u21a9<\/p>\n<p>\u5404\u9805\u76ee\u306e\u30bf\u30a4\u30c8\u30eb\u304c\u4e0d\u81ea\u7136\u306a\u306e\u306f\u547d\u540d\u898f\u5247\u306b\u5f93\u3063\u3066\u3044\u308b\u305f\u3081\u3067\u3059\u3002 \u21a9<\/p>\n<p>Windows\u306e\u5834\u5408\u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d7\u306b\u306f\u3001\u30a2\u30d7\u30ea\u5074\u304b\u3089\u8a2d\u5b9a\u3059\u308b\u30bf\u30a4\u30d7\u3068\u3001\u30e6\u30fc\u30b6\u30fc\u304c\u4efb\u610f\u306b\u6307\u5b9a\u3059\u308b\u30bf\u30a4\u30d7\u304c\u3042\u308a\u307e\u3059\u3002\u30ea\u30f3\u30af\u5148\u306f\u5f8c\u8005\u3067\u3059\u304c\u305d\u308c\u306f\u8aac\u660e\u306e\u305f\u3081\u3067\u672c\u30d7\u30e9\u30b0\u30a4\u30f3\u3068\u306f\u95a2\u4fc2\u306a\u304f\u3001\u672c\u30d7\u30e9\u30b0\u30a4\u30f3\u3067\u306f\u524d\u8005\u30bf\u30a4\u30d7\u3067\u8a2d\u5b9a\u3057\u307e\u3059\u3002Windows\u3067\u306f\u30a2\u30d7\u30ea\u306e\u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d7\u306f\u8a2d\u5b9a &gt; \u30a2\u30d7\u30ea &gt; \u30b9\u30bf\u30fc\u30c8\u30a2\u30c3\u30d7\u304b\u3089\u78ba\u8a8d\u3067\u304d\u307e\u3059\u3002 \u21a9<\/p>\n<p>\u3042\u308b\u610f\u5473\u3053\u306e\u6ce8\u610f\u3082\u3068\u3044\u5099\u5fd8\u9332\u3092\u66f8\u304f\u305f\u3081\u306b\u672c\u6a5f\u80fd\u3092\u7d39\u4ecb\u3057\u307e\u3057\u305f\u3002 \u21a9<\/p>\n<p>\u672c\u6765\u306a\u3089\u30d1\u30e9\u30c0\u30a4\u30e0\u3068\u8a18\u8ff0\u3059\u308b\u3079\u304d\u7b87\u6240\u3067\u3059\u304c\u3001\u300c\u5927\u5207\u306b\u3057\u305f\u3044\u30d1\u30e9\u30c0\u30a4\u30e0\u300d\u7684\u306a\u610f\u5473\u3092\u6301\u305f\u305b\u305f\u304b\u3063\u305f\u305f\u3081\u3042\u3048\u3066\u4fa1\u5024\u89b3\u3068\u8868\u73fe\u3057\u307e\u3057\u305f\u3002\u64ec\u4eba\u6cd5\u3067\u3059\u3002 \u21a9<\/p>\n<p>TypeScript\u304c\u30bf\u30c1\u3001Rust\u304c\u30cd\u30b3\u3067\u305f\u307e\u306b\u30ea\u30d0\u3042\u308a\u304b\u306a\u3063\u3066&#8230;\u307e\u3041\u3069\u3063\u3061\u3067\u3082\u826f\u3044\u6d3e\u3067\u3059\u304c() \u21a9<\/p>\n<\/section>\n","protected":false},"excerpt":{"rendered":"<p>\u524d\u56de\u4f5c\u3063\u305faudio-bookmark\u306b\u3064\u3065\u304d\u3001Rust + React with Tauri \u3067\u307e\u305f\u307e\u305f\u81ea\u5df1 [&hellip;]<\/p>\n","protected":false},"author":12,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-45264","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>- Blog - Silicon Cloud<\/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:\/\/www.silicloud.com\/zh\/blog\/45264-2\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:description\" content=\"\u524d\u56de\u4f5c\u3063\u305faudio-bookmark\u306b\u3064\u3065\u304d\u3001Rust + React with Tauri \u3067\u307e\u305f\u307e\u305f\u81ea\u5df1 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2022-12-01T10:47:07+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-28T23:19:48+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/3-0.gif\" \/>\n<meta name=\"author\" content=\"\u9038, \u79d1\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u9038, \u79d1\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"15 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/\",\"name\":\"- Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2022-12-01T10:47:07+00:00\",\"dateModified\":\"2024-04-28T23:19:48+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/\"]}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487\",\"name\":\"\u9038, \u79d1\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g\",\"caption\":\"\u9038, \u79d1\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/keyi\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"- Blog - Silicon Cloud","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:\/\/www.silicloud.com\/zh\/blog\/45264-2\/","og_locale":"zh_CN","og_type":"article","og_description":"\u524d\u56de\u4f5c\u3063\u305faudio-bookmark\u306b\u3064\u3065\u304d\u3001Rust + React with Tauri \u3067\u307e\u305f\u307e\u305f\u81ea\u5df1 [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2022-12-01T10:47:07+00:00","article_modified_time":"2024-04-28T23:19:48+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d5df337434c4406cf345c\/3-0.gif"}],"author":"\u9038, \u79d1","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u9038, \u79d1","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"15 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/","name":"- Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2022-12-01T10:47:07+00:00","dateModified":"2024-04-28T23:19:48+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/"]}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/85c1dae56e6ea1e695c73d33c684d487","name":"\u9038, \u79d1","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/c94f6d9cbbfbca863fab309840bd690c153c95f8490c290ad2ed54dd693dad16?s=96&d=mm&r=g","caption":"\u9038, \u79d1"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/keyi\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/45264-2\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/45264","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/12"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=45264"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/45264\/revisions"}],"predecessor-version":[{"id":83841,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/45264\/revisions\/83841"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=45264"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=45264"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=45264"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}