• Qun Cheng's avatar
    Add `Card.filled` and `Card.outlined` factory methods (#136229) · 4a0f261b
    Qun Cheng authored
    Fixes #119401
    
    This PR is to:
    * add `Card.filled` and `Card.outlined` factory methods so that we can use tokens for these two types of cards to generate default theme instead of providing hard-corded values in example.
    * update card.2.dart example.
    * add test file for card.2.dart example.
    * fix some mismatch caused by editing the auto-generated defaults by hand in navigation_bar.dart and navigation_drawer.dart.
    Unverified
    4a0f261b
card.2_test.dart 2.38 KB
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import 'package:flutter/material.dart';
import 'package:flutter_api_samples/material/card/card.2.dart' as example;
import 'package:flutter_test/flutter_test.dart';

void main() {
  testWidgets('Card variants', (WidgetTester tester) async {
    await tester.pumpWidget(const example.CardExamplesApp());

    expect(find.byType(Card), findsNWidgets(3));

    expect(find.widgetWithText(Card, 'Elevated Card'), findsOneWidget);
    expect(find.widgetWithText(Card, 'Filled Card'), findsOneWidget);
    expect(find.widgetWithText(Card, 'Outlined Card'), findsOneWidget);

    Material getCardMaterial(WidgetTester tester, int cardIndex) {
      return tester.widget<Material>(
        find.descendant(
          of: find.byType(Card).at(cardIndex),
          matching: find.byType(Material),
        ),
      );
    }

    final Material defaultCard = getCardMaterial(tester, 0);
    expect(defaultCard.clipBehavior, Clip.none);
    expect(defaultCard.elevation, 1.0);
    expect(defaultCard.shape, const RoundedRectangleBorder(
      borderRadius: BorderRadius.all(Radius.circular(12.0)),
    ));
    expect(defaultCard.color, const Color(0xfffffbfe));
    expect(defaultCard.shadowColor, const Color(0xff000000));
    expect(defaultCard.surfaceTintColor, const Color(0xff6750a4));

    final Material filledCard = getCardMaterial(tester, 1);
    expect(filledCard.clipBehavior, Clip.none);
    expect(filledCard.elevation, 0.0);
    expect(filledCard.shape, const RoundedRectangleBorder(
      borderRadius: BorderRadius.all(Radius.circular(12.0)),
    ));
    expect(filledCard.color, const Color(0xffe7e0ec));
    expect(filledCard.shadowColor, const Color(0xff000000));
    expect(filledCard.surfaceTintColor, const Color(0x00000000));

    final Material outlinedCard = getCardMaterial(tester, 2);
    expect(outlinedCard.clipBehavior, Clip.none);
    expect(outlinedCard.elevation, 0.0);
    expect(outlinedCard.shape, const RoundedRectangleBorder(
      side: BorderSide(color: Color(0xffcac4d0)),
      borderRadius: BorderRadius.all(Radius.circular(12.0)),
    ));
    expect(outlinedCard.color, const Color(0xfffffbfe));
    expect(outlinedCard.shadowColor, const Color(0xff000000));
    expect(outlinedCard.surfaceTintColor, const Color(0xff6750a4));
  });
}