test
This commit is contained in:
		| @@ -4,6 +4,7 @@ import 'package:oc_front/widgets/items/item_row.dart'; | ||||
| import 'package:oc_front/models/resources/resources.dart'; | ||||
| import 'package:oc_front/core/models/workspace_local.dart'; | ||||
|  | ||||
| // ignore: must_be_immutable | ||||
| class CatalogWidget extends StatefulWidget { | ||||
|   double? itemWidth; | ||||
|   bool readOnly = false; | ||||
|   | ||||
| @@ -252,7 +252,7 @@ class SchedulerFormsWidgetState extends State<SchedulerFormsWidget> { | ||||
|                                           cardTheme: CardTheme(elevation: 0, shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(0))), | ||||
|                                           dialogTheme: DialogTheme(elevation: 0, shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(0))), | ||||
|                                           colorScheme: ColorScheme.light( | ||||
|                                             background: midColor, | ||||
|                                             surface: midColor, | ||||
|                                             tertiary: Colors.grey, | ||||
|                                             secondary: Colors.grey, | ||||
|                                             primary: Colors.black), | ||||
| @@ -353,7 +353,7 @@ class SchedulerFormsWidgetState extends State<SchedulerFormsWidget> { | ||||
|                                           cardTheme: CardTheme(elevation: 0, shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(0))), | ||||
|                                           dialogTheme: DialogTheme(elevation: 0, shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(0))), | ||||
|                                           colorScheme: ColorScheme.light( | ||||
|                                             background: midColor, | ||||
|                                             surface: midColor, | ||||
|                                             tertiary: Colors.grey, | ||||
|                                             secondary: Colors.grey, | ||||
|                                             primary: Colors.black), | ||||
| @@ -391,7 +391,7 @@ class SchedulerFormsWidgetState extends State<SchedulerFormsWidget> { | ||||
|                                             cardTheme: CardTheme(elevation: 0, shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(0))), | ||||
|                                             dialogTheme: DialogTheme(elevation: 0, shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(0))), | ||||
|                                             colorScheme: ColorScheme.light( | ||||
|                                               background: midColor, | ||||
|                                               surface: midColor, | ||||
|                                               tertiary: Colors.grey, | ||||
|                                               secondary: Colors.grey, | ||||
|                                               primary: Colors.black), | ||||
| @@ -470,15 +470,15 @@ class SchedulerFormsWidgetState extends State<SchedulerFormsWidget> { | ||||
|                                 filled: true, | ||||
|                                 hintText: "enter cron command...", | ||||
|                                 labelText: "cron", | ||||
|                                 errorStyle: TextStyle(height: 0), | ||||
|                                 hintStyle: TextStyle(fontSize: 10), | ||||
|                                 labelStyle: TextStyle(fontSize: 10), | ||||
|                                 errorStyle: const TextStyle(height: 0), | ||||
|                                 hintStyle: const TextStyle(fontSize: 10), | ||||
|                                 labelStyle: const TextStyle(fontSize: 10), | ||||
|                                 focusedErrorBorder: OutlineInputBorder(borderSide: BorderSide(color: widget.errorCron != null ? Colors.red : Colors.black)), | ||||
|                                 errorBorder: OutlineInputBorder(borderSide: BorderSide(color: widget.errorCron != null ? Colors.red : Colors.black)), | ||||
|                                 focusedBorder: OutlineInputBorder(borderSide: BorderSide(color: widget.errorCron != null ? Colors.red : Colors.black)), | ||||
|                                 enabledBorder: OutlineInputBorder(borderSide: BorderSide(color: widget.errorCron != null ? Colors.red : Colors.grey)), | ||||
|                                 border: OutlineInputBorder(borderSide: BorderSide(color: widget.errorCron != null ? Colors.red : Colors.grey)), | ||||
|                                 contentPadding: EdgeInsets.symmetric(horizontal: 10, vertical: 5), | ||||
|                                 contentPadding: const EdgeInsets.symmetric(horizontal: 10, vertical: 5), | ||||
|                               ), | ||||
|                           ))), | ||||
|       Container( | ||||
|   | ||||
| @@ -18,28 +18,6 @@ class SubExposeFormsWidget extends StatefulWidget { | ||||
| } | ||||
| class SubExposeFormsWidgetState extends State<SubExposeFormsWidget> { | ||||
|   @override Widget build(BuildContext context) { | ||||
|     print("qsfqs"); | ||||
|     try { | ||||
|       var w = SubTextInputWidget(subkey: "reference port", readOnly: widget.readOnly, | ||||
|         initialValue: widget.item.port != null ? '${widget.item.port}' : null,  | ||||
|         width: widget.width,  | ||||
|         empty: widget.empty,  | ||||
|         change: (value) {  | ||||
|                   try { | ||||
|                     widget.item.port = int.parse(value); | ||||
|                     Future.delayed(const Duration(seconds: 2), () { | ||||
|                       if (widget.item.port == int.parse(value) && int.parse(value) != 0) { | ||||
|                         widget.dash.saveDash(widget.dash.id, context); | ||||
|                       } | ||||
|                     }); | ||||
|                   } catch (e) {  widget.item.port = null; } | ||||
|                   var el = widget.dash.getElement(widget.elementID); | ||||
|                   el!.element = widget.item as dynamic; | ||||
|                 }); | ||||
|     } catch (e,s) { | ||||
|       print(e); | ||||
|       print(s); | ||||
|     } | ||||
|     return Column( children : [ | ||||
|       Container( margin: const EdgeInsets.only(left: 10, right: 10, top: 15), | ||||
|                   decoration: const BoxDecoration(border: Border( top: BorderSide(color: Colors.grey, width: 1))), | ||||
|   | ||||
| @@ -3,6 +3,7 @@ import 'package:oc_front/main.dart'; | ||||
| import 'package:oc_front/models/response.dart'; | ||||
| import 'package:oc_front/pages/shared.dart'; | ||||
|  | ||||
| // ignore: must_be_immutable | ||||
| class ShallowDropdownInputWidget extends StatefulWidget { | ||||
|   double? width; | ||||
|   double? height; | ||||
| @@ -30,10 +31,10 @@ class ShallowDropdownInputWidget extends StatefulWidget { | ||||
|  | ||||
|   bool deletion = false; | ||||
|  | ||||
|   ShallowDropdownInputWidget ({ Key? key, this.width, this.current, required this.all, this.prefixIcon, | ||||
|   ShallowDropdownInputWidget ({ super.key, this.width, this.current, required this.all, this.prefixIcon, | ||||
|   this.iconLoad, this.iconRemove, this.hint, this.filled, this.hintColor, this.color, this.height, | ||||
|   this.tooltipLoad, this.tooltipRemove, this.deletion = false, this.maptoDropdown, this.label, | ||||
|   required this.type, this.canLoad, this.canRemove, this.load, this.remove, this.change }): super(key: key); | ||||
|   required this.type, this.canLoad, this.canRemove, this.load, this.remove, this.change }); | ||||
|   @override ShallowDropdownInputWidgetState createState() => ShallowDropdownInputWidgetState(); | ||||
| } | ||||
| class ShallowDropdownInputWidgetState extends State<ShallowDropdownInputWidget> { | ||||
|   | ||||
| @@ -2,6 +2,7 @@ import 'package:flutter/material.dart'; | ||||
| import 'package:oc_front/main.dart'; | ||||
| import 'package:oc_front/pages/shared.dart'; | ||||
|  | ||||
| // ignore: must_be_immutable | ||||
| class ShallowTextInputWidget extends StatefulWidget { | ||||
|   double? width; | ||||
|   CollaborativeAreaType type = CollaborativeAreaType.workspace; | ||||
| @@ -31,11 +32,11 @@ class ShallowTextInputWidget extends StatefulWidget { | ||||
|  | ||||
|   String? attr; | ||||
|  | ||||
|   ShallowTextInputWidget ({ Key? key, this.width, this.current, this.attr, this.readOnly = false, this.alignment = MainAxisAlignment.start, | ||||
|   ShallowTextInputWidget ({ super.key, this.width, this.current, this.attr, this.readOnly = false, this.alignment = MainAxisAlignment.start, | ||||
|   this.iconLoad, this.iconRemove, this.hint, this.forms = const [], this.loadStr, | ||||
|   this.tooltipLoad = "", this.tooltipRemove = "", | ||||
|   this.filled, this.hintColor, this.color, | ||||
|   required this.type, this.canLoad, this.canRemove, this.load, this.remove, this.change }): super(key: key); | ||||
|   required this.type, this.canLoad, this.canRemove, this.load, this.remove, this.change }); | ||||
|   @override ShallowTextInputWidgetState createState() => ShallowTextInputWidgetState(); | ||||
|  | ||||
|   Map<String, dynamic> serialize() { | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| import 'package:flutter/material.dart'; | ||||
|  | ||||
| // ignore: must_be_immutable | ||||
| class SubDropdownInputWidget extends StatefulWidget { | ||||
|   String subkey; | ||||
|   double width; | ||||
|   | ||||
| @@ -4,7 +4,6 @@ import 'package:oc_front/models/resources/resources.dart'; | ||||
| import 'package:oc_front/models/response.dart'; | ||||
| import 'package:oc_front/pages/shared.dart'; | ||||
| import 'package:oc_front/widgets/inputs/shallow_dropdown_input.dart'; | ||||
| import 'package:oc_front/widgets/inputs/sub_dropdown_input%20.dart'; | ||||
|  | ||||
| // ignore: must_be_immutable | ||||
| class ItemWidget extends StatefulWidget { | ||||
| @@ -15,25 +14,26 @@ class ItemWidget extends StatefulWidget { | ||||
| class ItemWidgetState extends State<ItemWidget> { | ||||
|   @override Widget build(BuildContext context) { | ||||
|     List<Widget> widgets = [ | ||||
|       Container( margin: EdgeInsets.only(bottom: 20), | ||||
|       Container( margin: const EdgeInsets.only(bottom: 20), | ||||
|         decoration: BoxDecoration(border: Border(bottom: BorderSide(color: midColor))), | ||||
|         width: getMainWidth(context) / 2, | ||||
|         child: Center(child: Padding( padding: EdgeInsets.only(bottom: 20),  | ||||
|         child: const Center(child: Padding( padding: EdgeInsets.only(bottom: 20),  | ||||
|           child: Text("RESOURCE INFORMATIONS", style: TextStyle(fontSize: 18, color: Colors.grey, fontWeight: FontWeight.w500))))) | ||||
|     ]; | ||||
|     var infos = widget.item.infos(); | ||||
|     var count = 0; | ||||
|     for (var info in infos.keys) { | ||||
|       count++; | ||||
|       widgets.add(Padding( padding: EdgeInsets.symmetric(vertical: 5), child : Row(children: [ | ||||
|         Padding(  padding: EdgeInsets.only(left: 50, right: 10), child : Text("${info.toUpperCase().replaceAll("_", " ")} :", style: TextStyle(fontSize: 15, color: Colors.grey))), | ||||
|       widgets.add(Padding( padding: const EdgeInsets.symmetric(vertical: 5), child : Row(children: [ | ||||
|         Padding(  padding: const EdgeInsets.only(left: 50, right: 10), child : Text("${info.toUpperCase().replaceAll("_", " ")} :",  | ||||
|         style: const TextStyle(fontSize: 15, color: Colors.grey))), | ||||
|         Text("${infos[info] is bool ? (infos[info] == true ? "yes" : "no") : infos[info] ?? "unknown"}",  | ||||
|           overflow: TextOverflow.ellipsis, | ||||
|           style: TextStyle(fontSize: 15, color: Colors.black, fontWeight: FontWeight.w500)) | ||||
|           style: const TextStyle(fontSize: 15, color: Colors.black, fontWeight: FontWeight.w500)) | ||||
|       ]))); | ||||
|     } | ||||
|     if (count == 0 ) { | ||||
|         widgets.add(Center(child: Padding( padding: EdgeInsets.symmetric(vertical: 5), child : Row(children: [ | ||||
|         widgets.add(const Center(child: Padding( padding: EdgeInsets.symmetric(vertical: 5), child : Row(children: [ | ||||
|           Padding(  padding: EdgeInsets.only(left: 50, right: 10), child : Text("NO INFORMATION", style: TextStyle(fontSize: 15, color: Colors.grey))), | ||||
|         ])))); | ||||
|       } | ||||
| @@ -43,7 +43,7 @@ class ItemWidgetState extends State<ItemWidget> { | ||||
|       dpItems.add(Shallow(id: "$i", name: instance.name ?? ""));    | ||||
|     } | ||||
|     if (dpItems.isNotEmpty) { | ||||
|       widgetsInstance.add(Center( child: Padding(padding: EdgeInsets.only(bottom: 15), child:  | ||||
|       widgetsInstance.add(Center( child: Padding(padding: const EdgeInsets.only(bottom: 15), child:  | ||||
|         ShallowDropdownInputWidget( all: () async => dpItems, width: (getWidth(context) / 2) - 25,  | ||||
|         label: "instances", type: CollaborativeAreaType.resource, height: 65, | ||||
|           current: "${widget.item.selectedInstance}", change: (value) { | ||||
| @@ -54,21 +54,27 @@ class ItemWidgetState extends State<ItemWidget> { | ||||
|     } | ||||
|     if (widget.item.instances.length > widget.item.selectedInstance) { | ||||
|       var instance = widget.item.instances[widget.item.selectedInstance]; | ||||
|       widgetsInstance.add(Container(height: 20, width: getWidth(context) / 2,)); | ||||
|       widgetsInstance.add(SizedBox(height: 20, width: getWidth(context) / 2,)); | ||||
|       var count = 0; | ||||
|       for (var info in instance.infos().keys) { | ||||
|         if (instance.infos()[info] == null || instance.infos()[info] is List || instance.infos()[info] is Map) { continue; } | ||||
|         count++; | ||||
|         widgetsInstance.add(Center(child: Padding( padding: EdgeInsets.symmetric(vertical: 5), child : Row(children: [ | ||||
|           Padding(  padding: EdgeInsets.only(left: 50, right: 10), child : Text("${info.toUpperCase().replaceAll("_", " ")} :", style: TextStyle(fontSize: 15, color: Colors.grey))), | ||||
|         widgetsInstance.add(Center(child: Padding( padding: const EdgeInsets.symmetric(vertical: 5), child : Row(children: [ | ||||
|           Padding(  padding: const EdgeInsets.only(left: 50, right: 10),  | ||||
|             child : Text("${info.toUpperCase().replaceAll("_", " ")} :",  | ||||
|               style: const TextStyle(fontSize: 15, color: Colors.grey))), | ||||
|           Text("${instance.infos()[info] is bool ? (instance.infos()[info] == true ? "yes" : "no") : instance.infos()[info] ?? "unknown"}",  | ||||
|             overflow: TextOverflow.ellipsis, | ||||
|             style: TextStyle(fontSize: 15, color: Colors.black, fontWeight: FontWeight.w500)) | ||||
|             style: const TextStyle(fontSize: 15, color: Colors.black, fontWeight: FontWeight.w500)) | ||||
|         ])))); | ||||
|       } | ||||
|       if (count == 0 ) { | ||||
|         widgetsInstance.add(Padding( padding: EdgeInsets.symmetric(vertical: 5), child : Row(children: [ | ||||
|           Padding(  padding: EdgeInsets.only(left: 50, right: 10), child : Text("NO INSTANCE INFORMATION", style: TextStyle(fontSize: 15, color: Colors.grey))), | ||||
|         widgetsInstance.add(const Padding(  | ||||
|           padding: EdgeInsets.symmetric(vertical: 5),  | ||||
|           child : Row(children: [ | ||||
|             Padding(  padding: EdgeInsets.only(left: 50, right: 10),  | ||||
|               child : Text("NO INSTANCE INFORMATION",  | ||||
|                 style: TextStyle(fontSize: 15, color: Colors.grey))), | ||||
|         ]))); | ||||
|       } | ||||
|     } | ||||
| @@ -87,7 +93,7 @@ class ItemWidgetState extends State<ItemWidget> { | ||||
|                   border: Border(bottom: BorderSide(color: midColor))), | ||||
|                 padding: const EdgeInsets.symmetric(vertical: 30, horizontal: 50),  | ||||
|                 child: Text(widget.item.description!.length > 350 ? "${widget.item.description!.substring(0, 347)}..." : widget.item.description!, | ||||
|                 style: TextStyle(fontSize: 15, color: Colors.grey, fontWeight: FontWeight.w500))),  | ||||
|                 style: const TextStyle(fontSize: 15, color: Colors.grey, fontWeight: FontWeight.w500))),  | ||||
|               Row( children: [  | ||||
|                 Container(padding: const EdgeInsets.symmetric(vertical: 20), | ||||
|                   height: getHeight(context) - 300, | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
| import 'dart:math'; | ||||
|  | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:flutter_flow_chart/flutter_flow_chart.dart'; | ||||
| import 'package:oc_front/main.dart'; | ||||
| @@ -43,7 +41,7 @@ class ShallowItemRowWidgetState extends State<ShallowItemRowWidget> { | ||||
|           child: Row( children: [ | ||||
|             Padding( padding: const EdgeInsets.only(right: 5), | ||||
|               child: widget.edit == null ? Container() : InkWell( mouseCursor:  SystemMouseCursors.click, | ||||
|               onTap: () =>  widget.edit!(widget.item.getID() + "~" + widget.item.getName()), child: const Icon(Icons.edit, color: Colors.grey,))), | ||||
|               onTap: () =>  widget.edit!( "${widget.item.getID()}~${widget.item.getName()}"), child: const Icon(Icons.edit, color: Colors.grey,))), | ||||
|             Padding( padding: const EdgeInsets.only(right: 5), | ||||
|               child: widget.delete == null ? Container() : InkWell( mouseCursor:  SystemMouseCursors.click, | ||||
|               onTap: () => widget.delete!(widget.item.getID()), child: const Icon(Icons.delete, color: Colors.grey,))), | ||||
| @@ -52,21 +50,19 @@ class ShallowItemRowWidgetState extends State<ShallowItemRowWidget> { | ||||
|         Column( children: [ | ||||
|           widget.low || widget.icon == null ? Container( padding: const EdgeInsets.only(left: 10),) : Container( padding: const EdgeInsets.all(10),  | ||||
|             constraints: BoxConstraints(maxWidth: widget.contextWidth, minWidth: widget.contextWidth), | ||||
|             child: Icon( widget.icon!, size: widget.contextWidth / 1.9, color: const Color(0xFFF67C0B9),)), | ||||
|             Container( | ||||
|               child: Padding(padding: widget.contextWidth != getMainWidth(context) ?  | ||||
|               const EdgeInsets.symmetric(horizontal: 10) : const EdgeInsets.symmetric(horizontal: 20), | ||||
|                 child: Column(crossAxisAlignment: CrossAxisAlignment.start,  | ||||
|                   mainAxisAlignment: MainAxisAlignment.center, children: [ | ||||
|                   Row( children: [  | ||||
|                     Expanded( child: Center( child: Text(widget.item.getName().toUpperCase(),  | ||||
|                       style: const TextStyle(fontSize: 15,  | ||||
|                       overflow: TextOverflow.ellipsis,  | ||||
|                       fontWeight: FontWeight.w600, color: Colors.grey)), | ||||
|                     )) | ||||
|                   ]), | ||||
|                 ],) | ||||
|               ) | ||||
|             child: Icon( widget.icon!, size: widget.contextWidth / 1.9, color: const Color(0xfff67c0b9),)), | ||||
|             Padding(padding: widget.contextWidth != getMainWidth(context) ?  | ||||
|             const EdgeInsets.symmetric(horizontal: 10) : const EdgeInsets.symmetric(horizontal: 20), | ||||
|               child: Column(crossAxisAlignment: CrossAxisAlignment.start,  | ||||
|                 mainAxisAlignment: MainAxisAlignment.center, children: [ | ||||
|                 Row( children: [  | ||||
|                   Expanded( child: Center( child: Text(widget.item.getName().toUpperCase(),  | ||||
|                     style: const TextStyle(fontSize: 15,  | ||||
|                     overflow: TextOverflow.ellipsis,  | ||||
|                     fontWeight: FontWeight.w600, color: Colors.grey)), | ||||
|                   )) | ||||
|                 ]), | ||||
|               ],) | ||||
|             ), | ||||
|           ]) | ||||
|         ])))); | ||||
| @@ -76,6 +72,7 @@ class ShallowItemRowWidgetState extends State<ShallowItemRowWidget> { | ||||
|   }  | ||||
| } | ||||
|  | ||||
| // ignore: must_be_immutable | ||||
| class ShallowItemFlowDataRowWidget extends StatefulWidget { | ||||
|   bool readOnly = false; | ||||
|   double contextWidth = 0; | ||||
| @@ -114,7 +111,7 @@ class ShallowItemFlowDataRowWidgetState extends State<ShallowItemFlowDataRowWidg | ||||
|           child: Row( children: [ | ||||
|             Padding( padding: const EdgeInsets.only(right: 5), | ||||
|               child: widget.edit == null ? Container() : InkWell( mouseCursor:  SystemMouseCursors.click, | ||||
|               onTap: () =>  widget.edit!(widget.item.getID() + "~" + widget.item.getName()), child: const Icon(Icons.edit, color: Colors.grey,))), | ||||
|               onTap: () =>  widget.edit!("${widget.item.getID()}~${widget.item.getName()}"), child: const Icon(Icons.edit, color: Colors.grey,))), | ||||
|             Padding( padding: const EdgeInsets.only(right: 5), | ||||
|               child: widget.delete == null ? Container() : InkWell( mouseCursor:  SystemMouseCursors.click, | ||||
|               onTap: () => widget.delete!(widget.item.getID()), child: const Icon(Icons.delete, color: Colors.grey,))), | ||||
| @@ -126,21 +123,19 @@ class ShallowItemFlowDataRowWidgetState extends State<ShallowItemFlowDataRowWidg | ||||
|         Column( children: [ | ||||
|           widget.low || widget.icon == null ? Container( padding: const EdgeInsets.only(left: 10),) : Container( padding: const EdgeInsets.all(10),  | ||||
|             constraints: BoxConstraints(maxWidth: widget.contextWidth, minWidth: widget.contextWidth), | ||||
|             child: Icon( widget.icon!, size: widget.contextWidth / 1.9, color: const Color(0xFFF67C0B9),)), | ||||
|             Container( | ||||
|               child: Padding(padding: widget.contextWidth != getMainWidth(context) ?  | ||||
|               const EdgeInsets.symmetric(horizontal: 10) : const EdgeInsets.symmetric(horizontal: 20), | ||||
|                 child: Column(crossAxisAlignment: CrossAxisAlignment.start,  | ||||
|                   mainAxisAlignment: MainAxisAlignment.center, children: [ | ||||
|                   Row( children: [  | ||||
|                     Expanded( child: Center( child: Text(widget.item.getName().toUpperCase(),  | ||||
|                       style: const TextStyle(fontSize: 15,  | ||||
|                       overflow: TextOverflow.ellipsis,  | ||||
|                       fontWeight: FontWeight.w600, color: Colors.grey)), | ||||
|                     )) | ||||
|                   ]), | ||||
|                 ],) | ||||
|               ) | ||||
|             child: Icon( widget.icon!, size: widget.contextWidth / 1.9, color: const Color(0xfff67c0b9),)), | ||||
|             Padding(padding: widget.contextWidth != getMainWidth(context) ?  | ||||
|             const EdgeInsets.symmetric(horizontal: 10) : const EdgeInsets.symmetric(horizontal: 20), | ||||
|               child: Column(crossAxisAlignment: CrossAxisAlignment.start,  | ||||
|                 mainAxisAlignment: MainAxisAlignment.center, children: [ | ||||
|                 Row( children: [  | ||||
|                   Expanded( child: Center( child: Text(widget.item.getName().toUpperCase(),  | ||||
|                     style: const TextStyle(fontSize: 15,  | ||||
|                     overflow: TextOverflow.ellipsis,  | ||||
|                     fontWeight: FontWeight.w600, color: Colors.grey)), | ||||
|                   )) | ||||
|                 ]), | ||||
|               ],) | ||||
|             ), | ||||
|           ]) | ||||
|         ])))); | ||||
|   | ||||
| @@ -10,12 +10,13 @@ import 'package:oc_front/core/services/specialized_services/logs_service.dart'; | ||||
|  | ||||
| bool isLoading = true; | ||||
| Map<String, bool> valid = {}; | ||||
| // ignore: must_be_immutable | ||||
| class LogsWidget extends StatefulWidget { | ||||
|   String? level; | ||||
|   String search = ""; | ||||
|   WorkflowExecution? exec; | ||||
|   List<Log> logs = []; | ||||
|   LogsWidget ({ Key? key, this.search = "", this.level, this.exec }): super(key: key); | ||||
|   LogsWidget ({ super.key, this.search = "", this.level, this.exec }); | ||||
|   @override LogsWidgetState createState() => LogsWidgetState(); | ||||
| } | ||||
|  | ||||
| @@ -73,12 +74,12 @@ class LogsWidgetState extends State<LogsWidget> { | ||||
|               List<LogWidget> itemRows = logs.where((element) => (element.message?.toLowerCase().contains(widget.search.toLowerCase()) ?? true) | ||||
|                 && (widget.level?.contains(element.level ?? "") ?? true) ).map((e) => LogWidget(item: e)).toList(); | ||||
|               if (isLoading) { | ||||
|                 return Container( height: getMainHeight(context) - 100, | ||||
|                     child: Center( child: CircularProgressIndicator()) ); | ||||
|                 return SizedBox( height: getMainHeight(context) - 100, | ||||
|                     child: const Center( child: CircularProgressIndicator()) ); | ||||
|               } | ||||
|               return Stack( children: [  | ||||
|                   SingleChildScrollView( child: itemRows.isEmpty ?  | ||||
|                   Container( height: getMainHeight(context) - 100, | ||||
|                   SizedBox( height: getMainHeight(context) - 100, | ||||
|                     child: const Center( child: Text("no log registered", style: TextStyle(color: Colors.grey, fontSize: 25 ),))) | ||||
|                   :  Column(  children:  [...itemRows, Container(height: 50,) ] ) ), | ||||
|                 ]); | ||||
| @@ -88,10 +89,11 @@ class LogsWidgetState extends State<LogsWidget> { | ||||
|   } | ||||
| } | ||||
|  | ||||
| // ignore: must_be_immutable | ||||
| class LogWidget extends StatefulWidget { | ||||
|   final Log item; | ||||
|   bool expanded = false; | ||||
|   LogWidget ({ Key? key, required this.item }): super(key: key); | ||||
|   LogWidget ({ super.key, required this.item }); | ||||
|   @override LogWidgetState createState() => LogWidgetState(); | ||||
| } | ||||
| class LogWidgetState extends State<LogWidget> { | ||||
|   | ||||
| @@ -44,7 +44,6 @@ class ScheduleWidgetState extends State<ScheduleWidget> { | ||||
|         "${widget.end.year}-${widget.end.month > 9 ? widget.end.month : "0${widget.end.month}"}-${widget.end.day > 9 ? widget.end.day : "0${widget.end.day}"}"], {}), | ||||
|       builder: (ctx, as) {  | ||||
|         Map<String, List<WorkflowExecution>> data = {}; | ||||
|         DateTime? firstDate;  | ||||
|         if (as.hasData && as.data!.data != null) { | ||||
|           for (var element in as.data!.data!.executions) { | ||||
|             if (element.startDate == null) { continue; } | ||||
| @@ -211,11 +210,11 @@ class ScheduleWidgetState extends State<ScheduleWidget> { | ||||
|                               borderSide: BorderSide(color: midColor, width: 0)), | ||||
|                           ), | ||||
|                           items: [ | ||||
|                             DropdownMenuItem(value: "debug,warning,error,info", child: Row( children: [ Container( width: 10, height: 15, color: Colors.grey), Text("  all", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "debug", child: Row( children: [ Container( width: 10, height: 15, color: Colors.blue), Text("  debug", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "warning", child: Row( children: [ Container( width: 10, height: 15, color: Colors.orange), Text("  warning", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "error", child: Row( children: [ Container( width: 10, height: 15, color: redColor), Text("  error", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "info", child: Row( children: [ Container( width: 10, height: 15, color: Colors.green), Text("  info", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "debug,warning,error,info", child: Row( children: [ Container( width: 10, height: 15, color: Colors.grey), const Text("  all", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "debug", child: Row( children: [ Container( width: 10, height: 15, color: Colors.blue), const Text("  debug", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "warning", child: Row( children: [ Container( width: 10, height: 15, color: Colors.orange), const Text("  warning", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "error", child: Row( children: [ Container( width: 10, height: 15, color: redColor), const Text("  error", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                             DropdownMenuItem(value: "info", child: Row( children: [ Container( width: 10, height: 15, color: Colors.green), const Text("  info", style: TextStyle(fontSize: 12, color: Colors.black)) ])), | ||||
|                           ],  | ||||
|                           onChanged: (value) { | ||||
|                             setState(() { | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| import 'package:flutter/material.dart'; | ||||
| import 'package:oc_front/core/sections/header/header.dart'; | ||||
| import 'package:oc_front/main.dart'; | ||||
| import 'package:oc_front/models/workflow.dart'; | ||||
| import 'package:oc_front/widgets/sheduler_items/schedule.dart'; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user