بدء استخدام Firebase Data Connect باستخدام Flutter

في هذا الدليل السريع، ستنشئ قاعدة بيانات صغيرة نموذجية وتنفّذها، ثم ستصل إليها من واجهة أمامية باستخدام Flutter.

المتطلبات الأساسية

لإكمال هذا التشغيل السريع، ستحتاج إلى ما يلي:

برنامج تعليمي

برنامج تعليمي

1. إعداد مشروعك

أنشئ دليلاً جديدًا وأضِف إليه مشروع Firebase. عند المطالبة، حدِّد الخيارات التالية:

  • أنشِئ مشروع Firebase جديدًا.
  • لا تنشئ مخططًا باستخدام Gemini (في هذا البرنامج التعليمي، ستستخدم مخطط مثال تم إنشاؤه مسبقًا).
  • أنشئ مثيلاً جديدًا من Cloud SQL.
  • أنشئ نموذج Flutter.
mkdir myproj ; cd myproj
firebase login --reauth
firebase init dataconnect

2. مراجعة أمثلة على تعريفات GraphQL

في Data Connect، يمكنك تحديد جميع مخططات قاعدة البيانات وعملياتها باستخدام GraphQL. عند إعداد مشروعك، أنشأ Firebase CLI بعض تعريفات الأمثلة لمساعدتك على البدء.

dataconnect/schema/schema.gql (مقتطف)
type Movie @table {
  title: String!
  imageUrl: String!
  genre: String
}

type MovieMetadata @table {
  movie: Movie! @unique
  rating: Float
  releaseYear: Int
  description: String
}
dataconnect/example/queries.gql (مقتطف)
query ListMovies @auth(level: PUBLIC) {
  movies {
    id
    title
    imageUrl
    genre
  }
}

3- نشر المخططات والعمليات

عند إجراء تغييرات على مخططات قاعدة البيانات أو طلبات البحث أو عمليات التعديل، عليك نشرها حتى يتم تطبيق التغييرات على قاعدة البيانات.

firebase deploy --only dataconnect

4. تعبئة قاعدة البيانات ببيانات نموذجية

ستوفّر لك بيانات البداية هذه بعض المعلومات التي يمكنك الاطّلاع عليها عند اختبار التطبيق النموذجي. يُرجى العِلم أنّه في هذه الخطوة، يمكنك تنفيذ أي طلبات GraphQL، وهو أمر مسموح به للمهام الإدارية.

firebase dataconnect:execute dataconnect/seed_data.gql

5- إنشاء حزمة SDK لبرنامج Dart

يستخدم هذا الأمر تعريفات GraphQL لإنشاء مكتبة Dart مخصّصة لقاعدة البيانات. يمكنك استخدام هذه المكتبة في تطبيق العميل لتنفيذ جميع عمليات قاعدة البيانات.

يمكنك إنشاء مكتبات لمنصات متعددة، بما في ذلك Kotlin لنظام Android وSwift لنظام iOS وJavaScript للويب، وذلك عن طريق إضافة تعريفات إلى connector.yaml.

firebase dataconnect:sdk:generate
مقتطف من حزمة تطوير البرامج (SDK) لـ Dart التي يتم إنشاؤها تلقائيًا
class ExampleConnector {
  ListMoviesVariablesBuilder listMovies() {
    return ListMoviesVariablesBuilder(dataConnect);
  }

  // ...
}

6. إعداد تطبيق Flutter

نفِّذ الأوامر التالية لإعداد تطبيق Flutter لاستخدام مشروع Firebase.

عندما يُطلب منك ذلك باستخدام الأمر flutterfire، اختَر مشروع Firebase الذي أنشأته سابقًا، واختَر المنصّات التي تريد استهدافها.

cd flutter_app
flutter pub add firebase_core firebase_data_connect
flutterfire configure

7. كتابة نموذج عميل Flutter

استبدِل محتوى flutter_app/lib/main.dart بهذا التطبيق البسيط المتوافق مع Flutter.

لاحظ أنّ التطبيق يكمل عملية الوصول اللازمة إلى قاعدة البيانات باستخدام دالة من حزمة SDK التي تم إنشاؤها.

import 'package:firebase_core/firebase_core.dart';
import 'package:firebase_data_connect/firebase_data_connect.dart';
import 'package:flutter/material.dart';
import 'package:flutter_app/dataconnect_generated/generated.dart';
import 'package:flutter_app/firebase_options.dart';

class MyApp extends StatelessWidget {
  late final Future<QueryResult<ListMoviesData, void>>
  _movieListFuture;

  MyApp({super.key}) {
    _movieListFuture = ExampleConnector.instance
        .listMovies()
        .execute();
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: FutureBuilder(
        future: _movieListFuture,
        builder: (context, snapshot) {
          if (snapshot.connectionState == ConnectionState.done) {
            return ListView.builder(
              scrollDirection: Axis.vertical,
              itemBuilder: (context, index) => Card(
                child: Text(
                  snapshot.data?.data.movies[index].title ?? "",
                ),
              ),
              itemCount: snapshot.data?.data.movies.length ?? 0,
            );
          }
          return const CircularProgressIndicator();
        },
      ),
    );
  }
}

Future<void> main() async {
  await Firebase.initializeApp(
    options: DefaultFirebaseOptions.currentPlatform,
  );
  runApp(MyApp());
}

8. جرّب التطبيق

ابدأ تشغيل خادم التطوير لمشاهدة مثال التطبيق أثناء عمله.

flutter run

الخطوات التالية

تجربة إضافة Visual Studio Code

عند التطوير باستخدام Data Connect، ننصح بشدة باستخدام إضافة Visual Studio Code. حتى إذا لم تكن تستخدم Visual Studio Code كبيئة التطوير الأساسية، يوفّر لك هذا الامتداد العديد من الميزات التي تجعل عملية تطوير المخططات والعمليات أكثر ملاءمة:

  • خادم لغة GraphQL يوفّر عمليات التحقّق من البنية واقتراحات الإكمال التلقائي الخاصة بـ Data Connect
  • أزرار CodeLens في سطر الرمز البرمجي تتيح لك قراءة البيانات وكتابتها من ملفات تعريف المخطط وتنفيذ طلبات البحث وعمليات التعديل من تعريفات العمليات.
  • الحفاظ على مزامنة حِزم SDK التي تم إنشاؤها تلقائيًا مع تعريفات GraphQL
  • إعداد مبسّط للمحاكي المحلي
  • نشر مبسّط للإصدار العلني

استخدام محاكي Data Connect للتطوير المحلي

على الرغم من أنّ هذا البرنامج التعليمي قد أوضح لك كيفية نشر مخططات Data Connect وعملياتها مباشرةً، من المحتمل أنّك لن تريد إجراء تغييرات على قاعدة بياناتك النشطة أثناء تطوير تطبيقك. بدلاً من ذلك، يمكنك إعداد محاكي Data Connect وإجراء عملية التطوير عليه بدلاً من قاعدة البيانات النشطة. يُعدّ المحاكي مثيلاً محليًا من PGlite يعمل بشكل مشابه لمثيل Postgres نشط على CloudSQL.

التعرّف على كيفية كتابة المخططات والعمليات لتطبيقك

عند تطوير تطبيقات باستخدام Data Connect، يكون تصميم المخططات والعمليات من أولى مهام التطوير وأهمها التي ستُكملها.

  • ‫"Gemini في وحدة تحكّم Firebase" هي أداة مستندة إلى الذكاء الاصطناعي يمكنها إنشاء مخططات Data Connect من وصف بلغة طبيعية لتطبيقك. يمكن أن تساعدك هذه الأداة في البدء بسرعة كبيرة، خاصةً إذا لم يسبق لك العمل مع قواعد البيانات العلائقية.
  • بدلاً من ذلك، يمكنك كتابة مخططات قاعدة البيانات والاستعلامات والتعديلات مباشرةً باستخدام GraphQL. ابدأ بصفحة مخططات Data Connect التصميم وتابِع إلى الصفحات التالية للتعرّف على كيفية كتابة العمليات.