Open5

Flutterのlayoutを理解したい

JboyHashimotoJboyHashimoto

アプリのlayoutわかっていない。

どんなものを参考にすればいいのか?
monoさんの昔のブログに、参考になりそうな情報が載っていた!

https://medium.com/flutter-jp/flutter-learning-c5640c5f05b9

🧑‍🎓昔のサイトだけど参考になった!

layoutについては、昔から変わることがないので、こちらが参考になった!
https://medium.com/flutter-community/flutter-layout-cheat-sheet-5363348d037e

AppBarに自分の配置したいパーツを置きたい。

やったこと

  1. leadingはデフォルトだと、幅が狭いので、leadingWidth: 200を指定して、横幅を広げた
  2. 2行、3列のメニューを作るには、Columnの中に、Rowを2個配置する
  3. mainAxisAlignment: MainAxisAlignment.spaceEvenlyを使ってメニューのテキストの幅を均一にした
import 'package:flutter/material.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key, required this.title});

  final String title;

  
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        leadingWidth: 200, // leadingの幅を指定
        leading: Container(
          // AppBarの左側にWidgetを配置する
          color: Colors.yellow,
          width: 200,
          height: 200,
          child: Column(
            children: [
              const SizedBox(height: 20),
              Container(
                color: Colors.red,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.spaceEvenly, // 余白を均等に配置
                  children: [
                    const Text('Top'),
                    const SizedBox(width: 10),
                    const Text('menu'),
                    const SizedBox(width: 10),
                    const Text('info'),
                    const SizedBox(width: 10),
                  ],
                ),
              ),
              const SizedBox(height: 20),
              Container(
                color: Colors.blue,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                  children: [
                    const Text('Top'),
                    const SizedBox(width: 10),
                    const Text('menu'),
                    const SizedBox(width: 10),
                    const Text('info'),
                    const SizedBox(width: 10),
                  ],
                ),
              ),
            ],
          ),
        ),
        actions: [
          Container(
            color: Colors.green,
            width: 200,
            child: Column(
              children: [
                const SizedBox(height: 20),
                Container(
                  color: Colors.red,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      const Text('Top'),
                      const SizedBox(width: 10),
                      const Text('menu'),
                      const SizedBox(width: 10),
                      const Text('info'),
                      const SizedBox(width: 10),
                    ],
                  ),
                ),
                const SizedBox(height: 20),
                Container(
                  color: Colors.blue,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      const Text('Top'),
                      const SizedBox(width: 10),
                      const Text('menu'),
                      const SizedBox(width: 10),
                      const Text('info'),
                      const SizedBox(width: 10),
                    ],
                  ),
                ),
              ],
            ),
          )
        ],
        toolbarHeight: 100,
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text(widget.title),
      ),
    );
  }
}

🔧ビルドした状態

均一に並べることができた。

JboyHashimotoJboyHashimoto

画面左にサイドバーのようなものを作りたい場合はどうする?

NavitationRailというウイジェットを使うらしいが、これでは実現できそうになかった😅
Columnを使って、サイドバーのような見た目に見えるようにしてみた。

import 'package:flutter/material.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key, required this.title});

  final String title;

  
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        leadingWidth: 200, // leadingの幅を指定
        leading: Container(
          // AppBarの左側にWidgetを配置する
          color: Colors.yellow,
          width: 200,
          height: 200,
          child: Column(
            children: [
              const SizedBox(height: 20),
              Container(
                color: Colors.red,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.spaceEvenly, // 余白を均等に配置
                  children: [
                    const Text('Top'),
                    const SizedBox(width: 10),
                    const Text('menu'),
                    const SizedBox(width: 10),
                    const Text('info'),
                    const SizedBox(width: 10),
                  ],
                ),
              ),
              const SizedBox(height: 20),
              Container(
                color: Colors.blue,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                  children: [
                    const Text('Top'),
                    const SizedBox(width: 10),
                    const Text('menu'),
                    const SizedBox(width: 10),
                    const Text('info'),
                    const SizedBox(width: 10),
                  ],
                ),
              ),
            ],
          ),
        ),
        actions: [
          Container(
            color: Colors.green,
            width: 200,
            child: Column(
              children: [
                const SizedBox(height: 20),
                Container(
                  color: Colors.red,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      const Text('Top'),
                      const SizedBox(width: 10),
                      const Text('menu'),
                      const SizedBox(width: 10),
                      const Text('info'),
                      const SizedBox(width: 10),
                    ],
                  ),
                ),
                const SizedBox(height: 20),
                Container(
                  color: Colors.blue,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      const Text('Top'),
                      const SizedBox(width: 10),
                      const Text('menu'),
                      const SizedBox(width: 10),
                      const Text('info'),
                      const SizedBox(width: 10),
                    ],
                  ),
                ),
              ],
            ),
          )
        ],
        toolbarHeight: 100,
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text(widget.title),
      ),
      body: Container(
        width: 50,
        color: Colors.pinkAccent,
        child: Column (
          mainAxisAlignment: MainAxisAlignment.start,
          children: <Widget>[
            SizedBox(height: 20),
            Icon(Icons.star_outline, size: 30),
            // 横幅20のDividerを表示
            const SizedBox(
              width: 50,
              child: Divider(color: Colors.grey),
            ),
            SizedBox(height: 20),
            Icon(Icons.home, size: 30),
            SizedBox(height: 20),
            Icon(Icons.comment, size: 30),
            SizedBox(height: 20),
            Icon(Icons.add, size: 30),
            SizedBox(height: 20),
            Icon(Icons.settings, size: 30),
          ],
        ),
      ),
    );
  }
}

何とか、それっぽく見せてみた💦

JboyHashimotoJboyHashimoto

ダッシュボードぽい画面を作りたい

画面に左に、サイドバーぽく見せたウイジェットを配置して、右側の中央に、テキストと入力フォームを並べるのをやってみた。それっぽい見た目にはなったが、サイドバーはこれでいいか疑問?
レイアウトは、綺麗にはできた。

import 'package:flutter/material.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key, required this.title});

  final String title;

  
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  final inputValues = [
    (title: '会社名', controller: TextEditingController()),
    (title: '事業者番号', controller: TextEditingController()),
    (title: '事業者名', controller: TextEditingController()),
    (title: '事業者名カナ', controller: TextEditingController()),
    (title: '郵便番号', controller: TextEditingController()),
    (title: '都道府県', controller: TextEditingController()),
    (title: '市町村', controller: TextEditingController()),
    (title: '番地', controller: TextEditingController()),
    (title: '建物名', controller: TextEditingController()),
    (title: '会社電話', controller: TextEditingController()),
    (title: '会社FAX', controller: TextEditingController()),
    (title: '会社メールアドレス', controller: TextEditingController()),
  ];

  /// titleからcontrollerに入力されたテキスト情報を取得する
  String controllerFromTitle(String title) => inputValues
      .firstWhere((element) => element.title == title)
      .controller
      .text;

  
  void dispose() {
    for (final value in inputValues) {
      value.controller.dispose();
    }
    super.dispose();
  }

  
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        leadingWidth: 200, // leadingの幅を指定
        leading: Container(
          // AppBarの左側にWidgetを配置する
          color: Colors.yellow,
          width: 200,
          height: 200,
          child: Column(
            children: [
              const SizedBox(height: 20),
              Container(
                color: Colors.red,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.spaceEvenly, // 余白を均等に配置
                  children: [
                    const Text('Top'),
                    const SizedBox(width: 10),
                    const Text('menu'),
                    const SizedBox(width: 10),
                    const Text('info'),
                    const SizedBox(width: 10),
                  ],
                ),
              ),
              const SizedBox(height: 20),
              Container(
                color: Colors.blue,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                  children: [
                    const Text('Top'),
                    const SizedBox(width: 10),
                    const Text('menu'),
                    const SizedBox(width: 10),
                    const Text('info'),
                    const SizedBox(width: 10),
                  ],
                ),
              ),
            ],
          ),
        ),
        actions: [
          Container(
            color: Colors.green,
            width: 200,
            child: Column(
              children: [
                const SizedBox(height: 20),
                Container(
                  color: Colors.red,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      const Text('Top'),
                      const SizedBox(width: 10),
                      const Text('menu'),
                      const SizedBox(width: 10),
                      const Text('info'),
                      const SizedBox(width: 10),
                    ],
                  ),
                ),
                const SizedBox(height: 20),
                Container(
                  color: Colors.blue,
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                    children: [
                      const Text('Top'),
                      const SizedBox(width: 10),
                      const Text('menu'),
                      const SizedBox(width: 10),
                      const Text('info'),
                      const SizedBox(width: 10),
                    ],
                  ),
                ),
              ],
            ),
          )
        ],
        toolbarHeight: 100,
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text(widget.title),
      ),
      body: SingleChildScrollView(// Widgetが増えた気に、overflowしないようにする
        child: Stack(// サイドバーとフォームを重ねる
          children: [
            Container(
              height: MediaQuery.of(context).size.height, // 画面の高さを取得して、画面下の余白をなくす
              color: Colors.lightBlueAccent,
              child: Column(
                mainAxisAlignment: MainAxisAlignment.start,
                children: [
                  const SizedBox(height: 40),
                  // for文を使って、TextEditingControllerを生成
                  for (final e in inputValues)
                    Padding(
                      padding: const EdgeInsets.only(bottom: 12),// 下の余白を12にする
                      child: TextFormFieldWithTitle(// コンポーネント化した、TextFormFieldを呼び出す
                        inputValue: e,// 生成したTextEditingControllerを渡す
                      ),
                    ),
                ],
              ),
            ),
            Container(
              width: 50,
              height: MediaQuery.of(context).size.height, // 画面の高さを取得して、画面下の余白をなくす
              color: Colors.pinkAccent,
              child: Column(
                mainAxisAlignment: MainAxisAlignment.start,
                children: <Widget>[
                  SizedBox(height: 20),
                  Icon(Icons.star_outline, size: 30),
                  // 横幅20のDividerを表示
                  const SizedBox(
                    width: 50,
                    child: Divider(color: Colors.grey),
                  ),
                  SizedBox(height: 20),
                  Icon(Icons.home, size: 30),
                  SizedBox(height: 20),
                  Icon(Icons.comment, size: 30),
                  SizedBox(height: 20),
                  Icon(Icons.add, size: 30),
                  SizedBox(height: 20),
                  Icon(Icons.settings, size: 30),
                ],
              ),
            ),
          ],
        ),
      ),
    );
  }
}
// 入力フォームをコンポーネント化する
class TextFormFieldWithTitle extends StatelessWidget {
  const TextFormFieldWithTitle({
    required this.inputValue,
    super.key,
  });

  final ({String title, TextEditingController controller}) inputValue;

  
  Widget build(BuildContext context) {
    return Row(
      mainAxisAlignment: MainAxisAlignment.center,
      crossAxisAlignment: CrossAxisAlignment.center,
      children: [
        SizedBox(
          width: 160,
          height: 40,
          child: Text(
            inputValue.title,
            style: const TextStyle(color: Colors.grey),
          ),
        ),
        SizedBox(
          width: 600,
          height: 40,
          child: TextFormField(
            controller: inputValue.controller,
            decoration: const InputDecoration(
              hintText: '○○○○○○○○○',
              fillColor: Colors.white,
              filled: true,
            ),
          ),
        ),
      ],
    );
  }
}

JboyHashimotoJboyHashimoto

パンくずリストのような見た目にする

https://www.xserver.ne.jp/bizhp/breadcrumbs/?gad=1&gclid=Cj0KCQjwqs6lBhCxARIsAG8YcDirdVZ-4KXKZux-ZOeXtD18uDyU9gK2qcACbUoAGABSFdf58QBQxjkaAqYaEALw_wcB

パンくずリストとは、ホームページを訪れたユーザーが、「現在どこのページにアクセスしているか」を知るための「道しるべ」です。

import 'package:dropdown_button2/dropdown_button2.dart';
import 'package:flutter/material.dart';

class BaseUI extends StatefulWidget {
  const BaseUI({Key? key}) : super(key: key);

  
  State<BaseUI> createState() => _BaseUIState();
}

class _BaseUIState extends State<BaseUI> {
  final fontColor = Colors.black;
  final List<String> items = [
    'Item1',
    'Item2',
    'Item3',
    'Item4',
    'Item5',
    'Item6',
    'Item7',
    'Item8',
  ];
  String? selectedValue;

  
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: Colors.grey[50],
      appBar: AppBar(
        backgroundColor: Colors.white,
        // 影を消す
        elevation: 0,
        leadingWidth: 500,
        // 高さ調整
        toolbarHeight: 100,
        leading: Padding(
          padding: const EdgeInsets.all(8.0),
          child: Column(
            children: [
              Row(
                children: [
                  Text('屋号', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('サービス種別', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('事業者番号', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                ],
              ),
              const SizedBox(height: 8),
              Row(
                children: [
                  Text('ようこそ', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('会社名', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('ログイン番号', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('ログイン名', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                ],
              ),
              const SizedBox(height: 8),
              Row(
                children: [
                  Text('台帳管理', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('アセスメント', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('予定・実績管理', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('国保連請求管理', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('各種情報出力', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                ],
              ),
            ],
          ),
        ),
        // AppBar右側にメニューを作る
        actions: [
          Padding(
            padding: const EdgeInsets.only(top: 8.0, right: 8.0),
            child: Align(
              alignment: Alignment.topRight,
              child: Row(
                children: [
                  Text('よくあるご質問', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('ログアウト', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('レセプトTOP', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                  Text('サイトTOP', style: TextStyle(color: fontColor)),
                  const SizedBox(width: 8),
                ],
              ),
            ),
          )
        ],
      ),
      body: SingleChildScrollView(
        child: Column(
          children: [
            const SizedBox(height: 10),
            Row(
              mainAxisAlignment: MainAxisAlignment.spaceBetween,
              children: [
                Container(
                  padding: const EdgeInsets.only(left: 40),
                  width: 300,
                  height: 100,
                  child: Column(
                    children: [
                      Row(
                        children: [
                          Text('TOP >'),
                          const SizedBox(width: 8),
                          Text('台帳管理 >'),
                          const SizedBox(width: 8),
                          Text('利用者管理画面'),
                        ],
                      ),
                      const SizedBox(height: 10),
                      Row(
                        children: [
                          Text('利用者管理画面', style: TextStyle(fontSize: 25)),
                        ],
                      ),
                    ],
                  ),
                ),
                Container(
                  // color: Colors.orange,
                  width: 440,
                  height: 120,
                  child: Column(
                    children: [
                      Container(
                        // color: Colors.cyan,
                        child: Row(
                          children: [
                            Column(
                              children: [
                                Container(
                                    // color: Colors.blue,
                                    alignment: Alignment.topLeft,
                                    width: 420,
                                    child: Text('スタッフ選択')),
                                const SizedBox(height: 10),
                                Row(
                                  children: [
                                    DropdownButtonHideUnderline(
                                      child: DropdownButton2<String>(
                                        isExpanded: true,
                                        hint: const Row(
                                          children: [
                                            SizedBox(
                                              width: 4,
                                            ),
                                            Expanded(
                                              child: Text(
                                                'Select Item',
                                                style: TextStyle(
                                                  fontSize: 14,
                                                  fontWeight: FontWeight.bold,
                                                ),
                                                overflow: TextOverflow.ellipsis,
                                              ),
                                            ),
                                          ],
                                        ),
                                        items: items
                                            .map((String item) =>
                                                DropdownMenuItem<String>(
                                                  value: item,
                                                  child: Text(
                                                    item,
                                                    style: const TextStyle(
                                                      fontSize: 14,
                                                      fontWeight:
                                                          FontWeight.bold,
                                                      color: Colors.black,
                                                    ),
                                                    overflow:
                                                        TextOverflow.ellipsis,
                                                  ),
                                                ))
                                            .toList(),
                                        value: selectedValue,
                                        onChanged: (value) {
                                          setState(() {
                                            selectedValue = value;
                                          });
                                        },
                                        buttonStyleData: ButtonStyleData(
                                          height: 50,
                                          width: 200,
                                          padding: const EdgeInsets.only(
                                              left: 14, right: 14),
                                          decoration: BoxDecoration(
                                            borderRadius:
                                                BorderRadius.circular(14),
                                            border: Border.all(
                                              color: Colors.black26,
                                            ),
                                            color: Colors.white,
                                          ),
                                          elevation: 2,
                                        ),
                                        iconStyleData: const IconStyleData(
                                          icon: Icon(
                                            Icons.keyboard_arrow_down,
                                          ),
                                          iconSize: 14,
                                          iconDisabledColor: Colors.grey,
                                        ),
                                        dropdownStyleData: DropdownStyleData(
                                          maxHeight: 200,
                                          width: 200,
                                          decoration: BoxDecoration(
                                            borderRadius:
                                                BorderRadius.circular(14),
                                            color: Colors.white,
                                          ),
                                          offset: const Offset(-20, 0),
                                          scrollbarTheme: ScrollbarThemeData(
                                            radius: const Radius.circular(40),
                                            thickness:
                                                MaterialStateProperty.all(6),
                                            thumbVisibility:
                                                MaterialStateProperty.all(true),
                                          ),
                                        ),
                                        menuItemStyleData:
                                            const MenuItemStyleData(
                                          height: 40,
                                          padding: EdgeInsets.only(
                                              left: 14, right: 14),
                                        ),
                                      ),
                                    ),
                                    const SizedBox(width: 40),
                                    SizedBox(
                                      width: 140,
                                      height: 30,
                                      child: ElevatedButton(
                                          onPressed: () {},
                                          child: const Text('検索')),
                                    ),
                                    SizedBox(width: 40),
                                  ],
                                ),
                              ],
                            ),
                          ],
                        ),
                      ),
                    ],
                  ),
                ),
              ],
            ),
          ],
        ),
      ),
    );
  }
}

パッケージもあるらしい?
https://pub.dev/packages/flutter_breadcrumb

JboyHashimotoJboyHashimoto

Webページのヘッダーをトレースする

ColumnとRowは、Containerでラップして、mainAxisAlignment: MainAxisAlignment.endにしないと、右端に寄せられなかった。

leadingは、Alignを使わないと、左端に寄せれなかった。

import 'package:flutter/material.dart';

class FreeUI extends StatefulWidget {
  const FreeUI({Key? key}) : super(key: key);

  
  State<FreeUI> createState() => _FreeUIState();
}

class _FreeUIState extends State<FreeUI> {
  
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
      backgroundColor: Colors.white,
      leadingWidth: 800,
      toolbarHeight: 100,
      elevation: 0, // 影を非表示
      leading: SizedBox(
        width: 200,
        height: 50,
        child: Column(
          mainAxisAlignment: MainAxisAlignment.start,
          children: [
            Align(
              alignment: Alignment.centerLeft,
              child: SizedBox(
                width: 200,
                height: 50,
                child: Image.network(
                    ''),
              ),
            ),
            Align(
              alignment: Alignment.centerLeft,
              child: Container(
                child: MenuBar(children: [
                  SubmenuButton(menuChildren: [
                    MenuItemButton(child: Text('Chick'), onPressed: () {}),
                  ], child: Icon(Icons.home)),
                  SubmenuButton(menuChildren: [
                    MenuItemButton(child: Text('Chick'), onPressed: () {}),
                  ], child: Icon(Icons.person)),
                  SubmenuButton(menuChildren: [
                    MenuItemButton(child: Text('Chick'), onPressed: () {}),
                  ], child: Icon(Icons.auto_graph_sharp)),
                  SubmenuButton(menuChildren: [
                    MenuItemButton(child: Text('Chick'), onPressed: () {}),
                  ], child: Icon(Icons.credit_card)),
                  SubmenuButton(menuChildren: [
                    MenuItemButton(child: Text('Chick'), onPressed: () {}),
                  ], child: Icon(Icons.money)),
                  SubmenuButton(menuChildren: [
                    MenuItemButton(child: Text('Chick'), onPressed: () {}),
                  ], child: Icon(Icons.business)),
                  SubmenuButton(menuChildren: [
                    MenuItemButton(child: Text('Chick'), onPressed: () {}),
                  ], child: Icon(Icons.settings)),
                ]),
              ),
            ),
          ],
        ),
      ),
      actions: [
        Container(
          width: 550,
          child: Padding(
            padding: const EdgeInsets.only(right: 20),
            child: Column(
              children: [
                SizedBox(height: 10),
                Container(
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.end,
                    children: [
                      Row(
                        children: [
                          Icon(Icons.play_arrow_rounded, color: Colors.black),
                          Text('連携アプリを探す',
                              style:
                                  TextStyle(color: Colors.black, fontSize: 12)),
                          SizedBox(width: 5),
                        ],
                      ),
                      Row(
                        children: [
                          Icon(Icons.apps, color: Colors.black),
                          Text('プロダクト切替',
                              style:
                                  TextStyle(color: Colors.black, fontSize: 12)),
                        ],
                      ),
                      SizedBox(width: 5),
                      Row(
                        children: [
                          Icon(Icons.person, color: Colors.black),
                          Text('アカウント',
                              style:
                                  TextStyle(color: Colors.black, fontSize: 12)),
                        ],
                      ),
                    ],
                  ),
                ),
                SizedBox(height: 10),
                Container(
                  child: Row(
                    mainAxisAlignment: MainAxisAlignment.end,
                    children: [
                      Text('レポート終了完了',
                          style: TextStyle(color: Colors.black, fontSize: 12)),
                      SizedBox(width: 5),
                      Text('コメント0件',
                          style: TextStyle(color: Colors.black, fontSize: 12)),
                      SizedBox(width: 5),
                      Text('スタータープラン',
                          style: TextStyle(color: Colors.black, fontSize: 12)),
                      SizedBox(width: 5),
                      Text('2023~01-01~2023-12-31',
                          style: TextStyle(color: Colors.black, fontSize: 12)),
                      SizedBox(width: 5),
                      Text('事業所名(未設定)',
                          style: TextStyle(color: Colors.black, fontSize: 12)),
                    ],
                  ),
                )
              ],
            ),
          ),
        )
      ],
    ));
  }
}