Getting started

With null-safety

Usage

If you are starting a new complex flutter app and need to build up your base widgets by the easiest way you will need to use app_fundamentals plugin. this is the available widgets you can try.

Add the dependency to your project and start using app_fundamentals #

dependencies:
   app_fundamentals : ^0.0.16

Importing the package #

import 'package:app_fundamentals/app_fundamentals.dart';

Examples

lets take for example the usage of BaseStatefulWidget if you extend BaseStatefulWidget to build your screen you can override multiple methods to easy create new screen in your app.

class MyPage extends BaseStatefulWidget {
  const OtpVerificationPageMobile({super.key});

  @override
  BaseState<MyPage> createState() =>
      _MyPageState();
}

class _MyPageState
    extends BaseState<OtpVerificationPageMobile> {
  ....
  @override
  void initState() {
  super.initState();
  ....
  }
  @override
  Widget setBody(BuildContext context) {
  return Container();
  }

  @override
  String? setScaffoldBackgroundImage() {
  return "";
  }

  @override
  Widget? setBottomNavigationBar() {
  return Container();
  }

  @override
  Future<bool> setOnWillPop() {
  return Future.value(true);
  }

  @override
  bool setResizeToAvoidBottomInset() {
  return false;
  }
}

as another example widget app_fundamental provide NavBarWidget and NavBarBloc to easy use NavBar in our app all you need to do is to use NavBarWidget in you StateFullWidget as BottomNavigationBar like this.

@override
Widget? setBottomNavigationBar() {
  return NavBarWidget(
      height: 64.0,
      textFontSize: 14.0,
      background: Colors.white,
      borderColor: Colors.black,
      selectedColor: Colors.blue,
      unSelectedColor: Colors.white,
      selectedFontWeight: FontWeight.w700,
      unSelectedFontWeight: FontWeight.w900,
      ....
  );
}

also you should identify your naveBarItemList by using navBarBloc like this.

navBarBloc.naveBarItemList = [
NavBarItem(
title:"Home",
widget: Container(),
selectedIcon: SvgPicture.asset(
selectedHomeSvg,
width: 24.0,
height: 24.0,
),
unSelectedIcon: SvgPicture.asset(
'assets/svg/home.svg',
width: 24.0,
height: 24.0,
),
onTap: () {
debugPrint('index 0');
},
),
NavBarItem(
.....
),
NavBarItem(
.....
),
];
AppButton
(
title: 'Back',
alignment: AppButtonAlign.start,
icon: SvgPicture.asset('assets/svg/backButtonIcon.svg'),
onTap: () => Navigator.pop(context)
);
AppText
(
label: 'Text',
textAlign: TextAlign.right,
style: TextStyle(
color: Colors.red,
fontSize: 14,
fontWeight: FontWeight.bold,
)
);
AppTextFormFieldItem
(
controller: TextEditingController(),
readOnly:
stateSnapshot.data?.status == RequestStatus.loading
? true
    : false,
autofocus: true,
title: AppLocalizations.of(context).email,
formFieldItemType: AppFormFieldItemType.email,
stream: _signInBloc.emailStream,
onChanged: _signInBloc.onChangedEmailField,
textInputType: TextInputType.emailAddress,
labelFontColor: Colors.black,
borderColor: Colors.grey,
focusedBorderColor: Colors.grey,
iconColor: Colors.black,
focusedIconColor: Colors.grey,
fillColor: Colors.white,
showHint: true,
validator: (val) => _signInBloc.validateEmail(val),
fontSize: 14.0,
contentPadding: EdgeInsets.symmetric(
horizontal: 8.0,
vertical: 8.0),
borderRadius: BorderRadius.all(
Radius.circular(8.0
)
)
);
AppBorderedDropDown(
            list: ["first", "second", "third"],
            selectedStateSubject: selectedStateSubject,
            selectedSubject: selectedSubject,
            borderColorSubject: borderColorSubject,
            onTap: (){},
            onChange: (val){},
            titleKey: "",
            label: "",
            hint: "",);
AppBottomSheet(context: context, widget: Container(),);
AppContainerWithLabel(label: Text("label"), child: widget,);
final AppDialog appDialog = AppDialog();
appDialog.child = AppDialogContent(title: "title",description: "description",);

...

Future<void> showAppDialog(AppDialog appDialog) async {
  await showDialog(
      context: context,
      barrierDismissible: false,
      builder: (BuildContext context) => appDialog);
}

Future<void>? hideAppDialog(AppDialog appDialog) {
  if (appDialog.isShowing()) {
    appDialog.pop();
    appDialog = AppDialog();
  }
  return null;
}
AppDivider(
          dividerPadding: EdgeInsets.symmetric(horizontal: 16.0),
          thickness: 2.0,
          dividerColor: Colors.grey,
        );
AppExpandedRadioButton(
          onTap: () {},
          label: "label",
          labelFontSize: 24.0,
          labelFontColor: Colors.black,
          isSelected: true,
        );
AppImage(
          path: "image_path",
          height: 40.0,
          width: 40.0,
          isCircular: true,
          boxFit: BoxFit.cover,
          color: Colors.white,
          onPressed: () {},
          defaultImage: AppImage(path: "default_image_path"),
          loadingWidget: LoadingWidget(),
        );
AppLabelWithIcon(
          label: "label",
          labelColor: Colors.black,
          icon: Icon(Icons.search),
        );
AppRefreshIndicator(
            child: Container(),
             onRefresh: () {},
             );
AppWebView(
        title: "title",
         url: "",
         );
final Encryptor encryptor = Encryptor();
      encryptor.encryptData("hello");
      encryptor.decryptData("efgdt-vvxvxxvxvxfgfg-bcbcbcbcbcbcbcbcbcbcb");

Improve

Help me by reporting bugs, submit new ideas for features or anything else that you want to share.

  • Just write an issue on GitHub. ✏️
  • And don't forget to hit the like button for this package ✌️

More

Check out my other useful packages on pub.dev

Libraries

app_fundamentals
========================================================== CREATED BY MOHAMED GHONEIM 01/01/2022 TEL// +201064626369