---
sidebar_position: 20
---
# Dogs API
```mdx-code-block
```
:::note
このチュートリアルは[@tatadan](https://twitter.com/tatadan)の好意により提供されたもので、[Wails Examples Repository](https://github.com/tataDan/wails-v2-examples)の一部を構成しています。
:::
このチュートリアルでは、Web上から犬の写真を取得し、表示するアプリケーションを開発します。
### プロジェクトを作成する
では、アプリケーションを作成しましょう。ターミナルで次のコマンドを入力します: `wails init -n dogs-api -t svelte`
注: IDEサポートを追加したい場合は、オプションでこのコマンドの最後に`-ide vscode`または`ide goland`を追加することができます。
では、cd `dogs-api`をして、プロジェクトファイルの編集を始めましょう。
### 未使用のコードを削除する
まず、使用しないことがわかっているいくつかの要素を削除することから始めます:
- `app.go`を開き、以下の行を削除してください:
```go
// Greet returns a greeting for the given name
func (a *App) Greet(name string) string {
return fmt.Sprintf("Hello %s, It's show time!", name)
}
```
- `frontend/src/App.svelte`を開き、すべての行を削除します。
- `frontend/src/assets/images/logo-universal.png`ファイルを削除します。
### アプリケーションの作成
では、新しいGoのコードを追加してみましょう。
`app.go`の関数定義の前に、次の構造体宣言を追加します:
```go
type RandomImage struct {
Message string
Status string
}
type AllBreeds struct {
Message map[string]map[string][]string
Status string
}
type ImagesByBreed struct {
Message []string
Status string
}
```
以下の関数を`app.go`に追加します(既存の関数定義の後ろに追加するかもしれません):
```go
func (a *App) GetRandomImageUrl() string {
response, err := http.Get("https://dog.ceo/api/breeds/image/random")
if err != nil {
log.Fatal(err)
}
responseData, err := ioutil.ReadAll(response.Body)
if err != nil {
log.Fatal(err)
}
var data RandomImage
json.Unmarshal(responseData, &data)
return data.Message
}
func (a *App) GetBreedList() []string {
var breeds []string
response, err := http.Get("https://dog.ceo/api/breeds/list/all")
if err != nil {
log.Fatal(err)
}
responseData, err := ioutil.ReadAll(response.Body)
if err != nil {
log.Fatal(err)
}
var data AllBreeds
json.Unmarshal(responseData, &data)
for k := range data.Message {
breeds = append(breeds, k)
}
sort.Strings(breeds)
return breeds
}
func (a *App) GetImageUrlsByBreed(breed string) []string {
url := fmt.Sprintf("%s%s%s%s", "https://dog.ceo/api/", "breed/", breed, "/images")
response, err := http.Get(url)
if err != nil {
log.Fatal(err)
}
responseData, err := ioutil.ReadAll(response.Body)
if err != nil {
log.Fatal(err)
}
var data ImagesByBreed
json.Unmarshal(responseData, &data)
return data.Message
}
```
`app.go`の`import`セクションを次のように変更します:
```go
import (
"context"
"fmt"
"encoding/json"
"io/ioutil"
"log"
"net/http"
"sort"
)
```
以下の行を`frontend/src/App.svelte`に追加します:
```html
```html
Dogs API
Click on down arrow to select a breed
{#if showRandomPhoto}
{/if}
{#if showBreedPhotos}
{#each photos as photo}
{/each}
{/if}
```
### アプリケーションのテスト
バインディングを生成し、アプリケーションをテストするには、`wails dev`を実行します。
### アプリケーションのコンパイル
アプリケーションを単一の、本番用のバイナリにコンパイルするには、`wails build`を実行します。