diff --git a/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_model.dart b/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_model.dart index a8efa6c4..8902a477 100644 --- a/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_model.dart +++ b/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_model.dart @@ -4,8 +4,7 @@ import 'package:hub/components/templates_components/visitor_search_modal_templat import 'package:hub/flutter_flow/flutter_flow_model.dart'; import 'package:hub/shared/utils/storage_util.dart'; -class VisitorSearchModalTemplateComponentModel - extends FlutterFlowModel { +class VisitorSearchModalTemplateComponentModel extends FlutterFlowModel { late final String devUUID; late final String userUUID; late final String cliUUID; @@ -14,18 +13,15 @@ class VisitorSearchModalTemplateComponentModel void addToVisitors(dynamic item) => visitors.add(item); void removeFromVisitors(dynamic item) => visitors.remove(item); void removeAtIndexFromVisitors(int index) => visitors.removeAt(index); - void insertAtIndexInVisitors(int index, dynamic item) => - visitors.insert(index, item); - void updateVisitorsAtIndex(int index, Function(dynamic) updateFn) => - visitors[index] = updateFn(visitors[index]); + void insertAtIndexInVisitors(int index, dynamic item) => visitors.insert(index, item); + void updateVisitorsAtIndex(int index, Function(dynamic) updateFn) => visitors[index] = updateFn(visitors[index]); List docs = []; void addToDocs(String item) => docs.add(item); void removeFromDocs(String item) => docs.remove(item); void removeAtIndexFromDocs(int index) => docs.removeAt(index); void insertAtIndexInDocs(int index, String item) => docs.insert(index, item); - void updateDocsAtIndex(int index, Function(String) updateFn) => - docs[index] = updateFn(docs[index]); + void updateDocsAtIndex(int index, Function(String) updateFn) => docs[index] = updateFn(docs[index]); FocusNode? textFieldFocusNode; TextEditingController? textController; diff --git a/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_widget.dart b/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_widget.dart index 29597fc5..f41722fa 100644 --- a/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_widget.dart +++ b/lib/components/templates_components/visitor_search_modal_template_component/visitor_search_modal_template_component_widget.dart @@ -26,13 +26,10 @@ class VisitorSearchModalTemplateComponentWidget extends StatefulWidget { final Future Function(List? docsParam)? getDocs; @override - State createState() => - _VisitorSearchModalTemplateComponentWidgetState(); + State createState() => _VisitorSearchModalTemplateComponentWidgetState(); } -class _VisitorSearchModalTemplateComponentWidgetState - extends State - with TickerProviderStateMixin { +class _VisitorSearchModalTemplateComponentWidgetState extends State with TickerProviderStateMixin { late VisitorSearchModalTemplateComponentModel _model; safeSetState(VoidCallback callback) { @@ -43,8 +40,7 @@ class _VisitorSearchModalTemplateComponentWidgetState @override void initState() { super.initState(); - _model = - createModel(context, () => VisitorSearchModalTemplateComponentModel()); + _model = createModel(context, () => VisitorSearchModalTemplateComponentModel()); _model.textController ??= TextEditingController(); _model.textFieldFocusNode ??= FocusNode(); @@ -85,8 +81,7 @@ class _VisitorSearchModalTemplateComponentWidgetState ), ), Padding( - padding: - const EdgeInsetsDirectional.fromSTEB(16.0, 25.0, 16.0, 0.0), + padding: const EdgeInsetsDirectional.fromSTEB(16.0, 25.0, 16.0, 0.0), child: TextFormField( controller: _model.textController, focusNode: _model.textFieldFocusNode, @@ -99,84 +94,41 @@ class _VisitorSearchModalTemplateComponentWidgetState obscureText: false, decoration: InputDecoration( isDense: true, - labelText: FFLocalizations.of(context).getText( - 'cjlpru1m' /* Procure pelo documento do visi... */, - ), + labelText: FFLocalizations.of(context).getText('cjlpru1m'), labelStyle: FlutterFlowTheme.of(context).labelMedium.override( - fontFamily: - FlutterFlowTheme.of(context).labelMediumFamily, + fontFamily: FlutterFlowTheme.of(context).labelMediumFamily, color: FlutterFlowTheme.of(context).primaryText, letterSpacing: 0.0, - useGoogleFonts: GoogleFonts.asMap().containsKey( - FlutterFlowTheme.of(context).labelMediumFamily), + useGoogleFonts: GoogleFonts.asMap().containsKey(FlutterFlowTheme.of(context).labelMediumFamily), ), enabledBorder: OutlineInputBorder( - borderSide: BorderSide( - color: FlutterFlowTheme.of(context).accent1, - width: 0.5, - ), - borderRadius: const BorderRadius.only( - bottomLeft: Radius.circular(15.0), - bottomRight: Radius.circular(15.0), - topLeft: Radius.circular(15.0), - topRight: Radius.circular(15.0), - ), + borderSide: BorderSide(color: FlutterFlowTheme.of(context).accent1, width: 0.5), + borderRadius: const BorderRadius.only(bottomLeft: Radius.circular(15.0), bottomRight: Radius.circular(15.0), topLeft: Radius.circular(15.0), topRight: Radius.circular(15.0)), ), focusedBorder: OutlineInputBorder( - borderSide: BorderSide( - color: FlutterFlowTheme.of(context).primary, - width: 0.5, - ), - borderRadius: const BorderRadius.only( - bottomLeft: Radius.circular(15.0), - bottomRight: Radius.circular(15.0), - topLeft: Radius.circular(15.0), - topRight: Radius.circular(15.0), - ), + borderSide: BorderSide(color: FlutterFlowTheme.of(context).primary, width: 0.5), + borderRadius: const BorderRadius.only(bottomLeft: Radius.circular(15.0), bottomRight: Radius.circular(15.0), topLeft: Radius.circular(15.0), topRight: Radius.circular(15.0)), ), errorBorder: OutlineInputBorder( - borderSide: BorderSide( - color: FlutterFlowTheme.of(context).error, - width: 0.5, - ), - borderRadius: const BorderRadius.only( - bottomLeft: Radius.circular(15.0), - bottomRight: Radius.circular(15.0), - topLeft: Radius.circular(15.0), - topRight: Radius.circular(15.0), - ), + borderSide: BorderSide(color: FlutterFlowTheme.of(context).error, width: 0.5), + borderRadius: const BorderRadius.only(bottomLeft: Radius.circular(15.0), bottomRight: Radius.circular(15.0), topLeft: Radius.circular(15.0), topRight: Radius.circular(15.0)), ), focusedErrorBorder: OutlineInputBorder( - borderSide: BorderSide( - color: FlutterFlowTheme.of(context).error, - width: 0.5, - ), - borderRadius: const BorderRadius.only( - bottomLeft: Radius.circular(15.0), - bottomRight: Radius.circular(15.0), - topLeft: Radius.circular(15.0), - topRight: Radius.circular(15.0), - ), + borderSide: BorderSide(color: FlutterFlowTheme.of(context).error, width: 0.5), + borderRadius: const BorderRadius.only(bottomLeft: Radius.circular(15.0), bottomRight: Radius.circular(15.0), topLeft: Radius.circular(15.0), topRight: Radius.circular(15.0)), ), filled: true, fillColor: FlutterFlowTheme.of(context).primaryBackground, - prefixIcon: Icon( - Icons.search_outlined, - color: FlutterFlowTheme.of(context).accent1, - ), + prefixIcon: Icon(Icons.search_outlined, color: FlutterFlowTheme.of(context).accent1), ), style: FlutterFlowTheme.of(context).bodyMedium.override( fontFamily: FlutterFlowTheme.of(context).bodyMediumFamily, letterSpacing: 0.0, - useGoogleFonts: GoogleFonts.asMap().containsKey( - FlutterFlowTheme.of(context).bodyMediumFamily), + useGoogleFonts: GoogleFonts.asMap().containsKey(FlutterFlowTheme.of(context).bodyMediumFamily), ), - keyboardType: - const TextInputType.numberWithOptions(signed: true), + keyboardType: const TextInputType.numberWithOptions(signed: true), validator: _model.textControllerValidator.asValidator(context), - inputFormatters: [ - FilteringTextInputFormatter.allow(RegExp('[0-9]')), - ], + inputFormatters: [FilteringTextInputFormatter.allow(RegExp('[0-9]'))], ), ), if (_model.visitors.isNotEmpty && _model.visitors.isNotEmpty) @@ -185,33 +137,25 @@ class _VisitorSearchModalTemplateComponentWidgetState mainAxisAlignment: MainAxisAlignment.start, children: [ Padding( - padding: const EdgeInsetsDirectional.fromSTEB( - 16.0, 12.0, 0.0, 0.0), + padding: const EdgeInsetsDirectional.fromSTEB(16.0, 12.0, 0.0, 0.0), child: Text( - FFLocalizations.of(context).getText( - '9coywebh' /* Visitantes encontrados */, - ), + FFLocalizations.of(context).getText('9coywebh'), style: FlutterFlowTheme.of(context).labelMedium.override( - fontFamily: - FlutterFlowTheme.of(context).labelMediumFamily, + fontFamily: FlutterFlowTheme.of(context).labelMediumFamily, color: FlutterFlowTheme.of(context).primaryText, letterSpacing: 0.0, - useGoogleFonts: GoogleFonts.asMap().containsKey( - FlutterFlowTheme.of(context).labelMediumFamily), + useGoogleFonts: GoogleFonts.asMap().containsKey(FlutterFlowTheme.of(context).labelMediumFamily), ), ), ), Padding( - padding: const EdgeInsetsDirectional.fromSTEB( - 4.0, 12.0, 16.0, 0.0), + padding: const EdgeInsetsDirectional.fromSTEB(4.0, 12.0, 16.0, 0.0), child: Text( _model.visitors.length.toString(), style: FlutterFlowTheme.of(context).bodyMedium.override( - fontFamily: - FlutterFlowTheme.of(context).bodyMediumFamily, + fontFamily: FlutterFlowTheme.of(context).bodyMediumFamily, letterSpacing: 0.0, - useGoogleFonts: GoogleFonts.asMap().containsKey( - FlutterFlowTheme.of(context).bodyMediumFamily), + useGoogleFonts: GoogleFonts.asMap().containsKey(FlutterFlowTheme.of(context).bodyMediumFamily), ), ), ), @@ -222,12 +166,10 @@ class _VisitorSearchModalTemplateComponentWidgetState builder: (context) { if (_model.visitors.isNotEmpty) { return Padding( - padding: const EdgeInsetsDirectional.fromSTEB( - 8.0, 8.0, 8.0, 0.0), + padding: const EdgeInsetsDirectional.fromSTEB(8.0, 8.0, 8.0, 0.0), child: Builder( builder: (context) { - final visitor = - _model.visitors.map((e) => e).toList(); + final visitor = _model.visitors.map((e) => e).toList(); final doc = _model.docs.map((e) => e).toList(); return ListView.builder( padding: EdgeInsets.zero, @@ -237,8 +179,7 @@ class _VisitorSearchModalTemplateComponentWidgetState final visitorItem = visitor[visitorIndex]; final docItem = doc[visitorIndex]; return Padding( - padding: const EdgeInsetsDirectional.fromSTEB( - 0.0, 0.0, 0.0, 1.0), + padding: const EdgeInsetsDirectional.fromSTEB(0.0, 0.0, 0.0, 1.0), child: InkWell( splashColor: Colors.transparent, focusColor: Colors.transparent, @@ -247,26 +188,20 @@ class _VisitorSearchModalTemplateComponentWidgetState child: Container( width: 100.0, decoration: BoxDecoration( - color: FlutterFlowTheme.of(context) - .primaryBackground, + color: FlutterFlowTheme.of(context).primaryBackground, ), child: Padding( padding: const EdgeInsets.all(8.0), child: Row( mainAxisSize: MainAxisSize.min, - crossAxisAlignment: - CrossAxisAlignment.center, + crossAxisAlignment: CrossAxisAlignment.center, children: [ ClipRRect( - borderRadius: - BorderRadius.circular(40.0), + borderRadius: BorderRadius.circular(40.0), child: CachedNetworkImage( - fadeInDuration: const Duration( - milliseconds: 500), - fadeOutDuration: const Duration( - milliseconds: 500), - imageUrl: - "https://freaccess.com.br/freaccess/getImage.php?devUUID=${_model.devUUID}&userUUID=${_model.userUUID}&cliID=${_model.cliUUID}&atividade=getFoto&Documento=${getJsonField( + fadeInDuration: const Duration(milliseconds: 500), + fadeOutDuration: const Duration(milliseconds: 500), + imageUrl: "https://freaccess.com.br/freaccess/getImage.php?devUUID=${_model.devUUID}&userUUID=${_model.userUUID}&cliID=${_model.cliUUID}&atividade=getFoto&Documento=${getJsonField( visitorItem, r'''$.VTE_DOCUMENTO''', ).toString()}&tipo=E", @@ -278,39 +213,20 @@ class _VisitorSearchModalTemplateComponentWidgetState Expanded( child: Column( mainAxisSize: MainAxisSize.max, - mainAxisAlignment: - MainAxisAlignment.center, - crossAxisAlignment: - CrossAxisAlignment.start, + mainAxisAlignment: MainAxisAlignment.center, + crossAxisAlignment: CrossAxisAlignment.start, children: [ Padding( - padding: - const EdgeInsetsDirectional - .fromSTEB( - 12.0, 0.0, 0.0, 0.0), + padding: const EdgeInsetsDirectional.fromSTEB(12.0, 0.0, 0.0, 0.0), child: Text( valueOrDefault( - getJsonField( - visitorItem, - r'''$.VTE_NOME''', - )?.toString(), + getJsonField(visitorItem, r'''$.VTE_NOME''')?.toString(), 'NOT FOUND', ), - style: FlutterFlowTheme.of( - context) - .bodyLarge - .override( - fontFamily: - FlutterFlowTheme.of( - context) - .bodyLargeFamily, + style: FlutterFlowTheme.of(context).bodyLarge.override( + fontFamily: FlutterFlowTheme.of(context).bodyLargeFamily, letterSpacing: 0.0, - useGoogleFonts: GoogleFonts - .asMap() - .containsKey( - FlutterFlowTheme.of( - context) - .bodyLargeFamily), + useGoogleFonts: GoogleFonts.asMap().containsKey(FlutterFlowTheme.of(context).bodyLargeFamily), ), ), ), @@ -321,16 +237,9 @@ class _VisitorSearchModalTemplateComponentWidgetState borderRadius: 20.0, borderWidth: 1.0, buttonSize: 40.0, - icon: Icon( - Icons.close, - color: - FlutterFlowTheme.of(context) - .customColor6, - size: 20.0, - ), + icon: Icon(Icons.close, color: FlutterFlowTheme.of(context).customColor6, size: 20.0), onPressed: () async { - _model.removeFromVisitors( - visitorItem); + _model.removeFromVisitors(visitorItem); _model.removeFromDocs(docItem); safeSetState(() {}); }, @@ -350,9 +259,7 @@ class _VisitorSearchModalTemplateComponentWidgetState return Container( width: 100.0, height: 100.0, - decoration: BoxDecoration( - color: FlutterFlowTheme.of(context).primaryBackground, - ), + decoration: BoxDecoration(color: FlutterFlowTheme.of(context).primaryBackground), ); } }, @@ -363,15 +270,7 @@ class _VisitorSearchModalTemplateComponentWidgetState mainAxisSize: MainAxisSize.max, children: [ FFButtonWidget( - onPressed: MediaQuery.of(context).viewInsets.bottom > 0 - ? () async { - await addVisitor(context); - - safeSetState(() {}); - } - : () async { - await sendVisitors(context); - }, + onPressed: MediaQuery.of(context).viewInsets.bottom > 0 ? () async => await addVisitor(context).whenComplete(safeSetState(() {})) : () async => await sendVisitors(context), text: MediaQuery.of(context).viewInsets.bottom > 0 ? FFLocalizations.of(context).getVariableText( enText: 'Add', @@ -384,37 +283,23 @@ class _VisitorSearchModalTemplateComponentWidgetState options: FFButtonOptions( width: MediaQuery.of(context).size.width * 0.3, height: MediaQuery.of(context).size.width * 0.1, - padding: const EdgeInsetsDirectional.fromSTEB( - 24.0, 0.0, 24.0, 0.0), - iconPadding: const EdgeInsetsDirectional.fromSTEB( - 0.0, 0.0, 0.0, 0.0), + padding: const EdgeInsetsDirectional.fromSTEB(24.0, 0.0, 24.0, 0.0), + iconPadding: const EdgeInsetsDirectional.fromSTEB(0.0, 0.0, 0.0, 0.0), color: FlutterFlowTheme.of(context).primary, textStyle: FlutterFlowTheme.of(context).titleSmall.override( - fontFamily: - FlutterFlowTheme.of(context).titleSmallFamily, + fontFamily: FlutterFlowTheme.of(context).titleSmallFamily, color: Colors.white, letterSpacing: 0.0, - useGoogleFonts: GoogleFonts.asMap().containsKey( - FlutterFlowTheme.of(context).titleSmallFamily), + useGoogleFonts: GoogleFonts.asMap().containsKey(FlutterFlowTheme.of(context).titleSmallFamily), ), elevation: 3.0, - borderSide: const BorderSide( - color: Colors.transparent, - width: 1.0, - ), - borderRadius: const BorderRadius.only( - bottomLeft: Radius.circular(15), - bottomRight: Radius.circular(15), - topLeft: Radius.circular(15), - topRight: Radius.circular(15), - ), + borderSide: const BorderSide(color: Colors.transparent, width: 1.0), + borderRadius: const BorderRadius.only(bottomLeft: Radius.circular(15), bottomRight: Radius.circular(15), topLeft: Radius.circular(15), topRight: Radius.circular(15)), ), ), ], ), - const SizedBox( - height: 30.0, - ) + const SizedBox(height: 30.0) ], ), ), @@ -422,9 +307,7 @@ class _VisitorSearchModalTemplateComponentWidgetState } Future sendVisitors(BuildContext context) async { - await widget.getVisitors?.call( - _model.visitors, - ); + await widget.getVisitors?.call(_model.visitors); log('() => docs: ${_model.docs}'); await widget.getDocs?.call(_model.docs); context.pop(); @@ -433,39 +316,20 @@ class _VisitorSearchModalTemplateComponentWidgetState Future addVisitor(BuildContext context) async { safeSetState(() { _model.textController?.text = _model.textController.text; - _model.textController?.selection = - TextSelection.collapsed(offset: _model.textController!.text.length); + _model.textController?.selection = TextSelection.collapsed(offset: _model.textController!.text.length); }); - _model.getVisitorByDoc = await PhpGroup.getVisitorByDocCall.call( - documento: _model.textController.text, - ); + _model.getVisitorByDoc = await PhpGroup.getVisitorByDocCall.call(documento: _model.textController.text.replaceFirst(RegExp(r'^0+'), '')); - if (PhpGroup.getVisitorByDocCall.vistanteId( - (_model.getVisitorByDoc?.jsonBody ?? ''), - ) != - '0' && - PhpGroup.getVisitorByDocCall - .error((_model.getVisitorByDoc?.jsonBody ?? '')) == - false && - PhpGroup.getVisitorByDocCall - .vistanteId((_model.getVisitorByDoc?.jsonBody ?? '')) != - null) { + if (PhpGroup.getVisitorByDocCall.vistanteId((_model.getVisitorByDoc?.jsonBody ?? '')) != '0' && PhpGroup.getVisitorByDocCall.error((_model.getVisitorByDoc?.jsonBody ?? '')) == false && PhpGroup.getVisitorByDocCall.vistanteId((_model.getVisitorByDoc?.jsonBody ?? '')) != null) { String newDoc = _model.textController.text; bool existDoc = _model.docs.contains(newDoc); if (existDoc == false) { - _model.addToVisitors(PhpGroup.getVisitorByDocCall.visitante( - (_model.getVisitorByDoc?.jsonBody ?? ''), - )); + _model.addToVisitors(PhpGroup.getVisitorByDocCall.visitante((_model.getVisitorByDoc?.jsonBody ?? ''))); safeSetState(() {}); _model.addToDocs(_model.textController.text); safeSetState(() {}); } else if (existDoc == true) { - ToastUtil.showToast( - message: FFLocalizations.of(context).getVariableText( - ptText: 'Visitante já adicionado!', - enText: 'Visitor already added!'), - gravity: ToastGravity.TOP, - backgroundColor: Colors.red); + ToastUtil.showToast(message: FFLocalizations.of(context).getVariableText(ptText: 'Visitante já adicionado!', enText: 'Visitor already added!'), gravity: ToastGravity.TOP, backgroundColor: Colors.red); } } else { await showAdaptiveDialog( @@ -473,9 +337,7 @@ class _VisitorSearchModalTemplateComponentWidgetState context: context, builder: (context) { return Dialog( - child: VisitorNotFoundComponentWidget( - doc: _model.textController.text, - ), + child: VisitorNotFoundComponentWidget(doc: _model.textController.text), ); }, ).then((value) => safeSetState(() {