delete file tamplate
This commit is contained in:
@@ -1 +1,4 @@
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:30:14.963Z"}
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:44:11.043Z"}
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T03:13:24.349Z"}
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at new eS (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:26724)\n at e_ (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27574)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32507)\n at get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32603)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39714)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:33303)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36)\n at run (node:async_hooks:64:22)","timestamp":"2025-02-05T03:48:26.606Z"}
|
||||
|
||||
@@ -1 +1,4 @@
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:30:14.963Z"}
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T02:44:11.043Z"}
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at Object.e_ [as staticGenerationBailout] (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27571)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32508)\n at Object.get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32604)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js:1:1219)\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39715\n at /Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36\n at NoopContextManager.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:7057)\n at ContextAPI.with (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:516)\n at NoopTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18086)\n at ProxyTracer.startActiveSpan (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/@opentelemetry/api/index.js:1:18847)","timestamp":"2025-02-05T03:13:24.349Z"}
|
||||
{"digest":"DYNAMIC_SERVER_USAGE","level":"error","message":"Error get data detail event: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error","stack":"Error: Dynamic server usage: Page couldn't be rendered statically because it used `request.url`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error\n at new eS (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:26724)\n at e_ (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:27574)\n at i (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32507)\n at get (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:32603)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at GET (/Users/bagasbanuna/Documents/BIP/hipmi/.next/server/app/api/event/check-peserta/route.js)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:39714)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/compiled/next-server/app-route.runtime.prod.js:14:33303)\n at <anonymous> (/Users/bagasbanuna/Documents/BIP/hipmi/node_modules/next/dist/server/lib/trace/tracer.js:121:36)\n at run (node:async_hooks:64:22)","timestamp":"2025-02-05T03:48:26.606Z"}
|
||||
|
||||
@@ -11,8 +11,7 @@ async function DELETE(request: Request) {
|
||||
}
|
||||
try {
|
||||
// Ambil parameter nomor dari URL
|
||||
const { searchParams } = new URL(request.url);
|
||||
const nomor = searchParams.get("nomor");
|
||||
const { nomor } = await request.json();
|
||||
|
||||
// Validasi parameter nomor
|
||||
if (!nomor) {
|
||||
@@ -27,6 +26,9 @@ async function DELETE(request: Request) {
|
||||
|
||||
// Cek apakah data OTP dengan nomor tersebut ada
|
||||
const existingOtp = await prisma.kodeOtp.findFirst({
|
||||
orderBy: {
|
||||
createdAt: "desc",
|
||||
},
|
||||
where: { nomor },
|
||||
});
|
||||
|
||||
|
||||
@@ -40,8 +40,12 @@ const apiDeleteAktivasiKodeOtpByNomor = async ({
|
||||
}: {
|
||||
nomor: string;
|
||||
}) => {
|
||||
const respone = await fetch(`/api/auth/delete/${nomor}`, {
|
||||
const respone = await fetch(`/api/auth/code`, {
|
||||
method: "DELETE",
|
||||
body: JSON.stringify({nomor}),
|
||||
headers: {
|
||||
"Content-Type": "application/json",
|
||||
}
|
||||
});
|
||||
|
||||
return await respone.json().catch(() => null);
|
||||
|
||||
@@ -129,6 +129,7 @@ export const middleware = async (req: NextRequest) => {
|
||||
// ==================== Authentication: Login, Validasi, Registrasi ==================== //
|
||||
// Token verification
|
||||
const user = await verifyToken({ token, encodedKey });
|
||||
console.log("middlaware",user)
|
||||
|
||||
// Handle login page access
|
||||
if (pathname === loginPath) {
|
||||
|
||||
@@ -1,82 +0,0 @@
|
||||
{
|
||||
"name": "base",
|
||||
"configs": [
|
||||
{
|
||||
"name": "bloc",
|
||||
"commands": [
|
||||
{
|
||||
"name": "[FF] New Big Pack Bloc",
|
||||
"templates": ["*"],
|
||||
"key": "bigpack",
|
||||
"files": [
|
||||
"bloc",
|
||||
"event",
|
||||
"index",
|
||||
"model",
|
||||
"page",
|
||||
"provider",
|
||||
"repository",
|
||||
"screen",
|
||||
"state"
|
||||
]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Small Pack Bloc",
|
||||
"templates": ["*"],
|
||||
"key": "smallpack",
|
||||
"files": ["bloc", "event", "index", "page", "screen", "state"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Bloc",
|
||||
"templates": ["*"],
|
||||
"files": ["bloc"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Event",
|
||||
"templates": ["*"],
|
||||
"files": ["event"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Model",
|
||||
"templates": ["*"],
|
||||
"files": ["model"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Page",
|
||||
"templates": ["*"],
|
||||
"files": ["page"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Provider",
|
||||
"templates": ["*"],
|
||||
"files": ["provider"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Repository",
|
||||
"templates": ["*"],
|
||||
"files": ["repository"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Screen",
|
||||
"templates": ["*"],
|
||||
"files": ["screen"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New State",
|
||||
"templates": ["*"],
|
||||
"files": ["state"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Index",
|
||||
"templates": ["*"],
|
||||
"files": ["index"]
|
||||
},
|
||||
{
|
||||
"name": "[FF] New Navigate(Navme)",
|
||||
"templates": ["navigate"],
|
||||
"files": ["navigate"]
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
@@ -1,16 +0,0 @@
|
||||
import 'package:ff_bloc/ff_bloc.dart';
|
||||
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Bloc extends FFBloc<${upperName}Event, ${upperName}State> {
|
||||
${upperName}Bloc({
|
||||
required this.provider,
|
||||
super.initialState = const ${upperName}State(),
|
||||
});
|
||||
/// Use this for all requests to backend - you can mock it in tests
|
||||
final ${upperName}Provider provider;
|
||||
|
||||
@override
|
||||
${upperName}State onErrorState(Object error) => state.copy(error: error, isLoading: false);
|
||||
|
||||
}
|
||||
@@ -1,78 +0,0 @@
|
||||
import 'dart:async';
|
||||
|
||||
import 'package:flutter/widgets.dart';
|
||||
import 'package:ff_bloc/ff_bloc.dart';
|
||||
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
@immutable
|
||||
abstract class ${upperName}Event implements FFBlocEvent<${upperName}State, ${upperName}Bloc> {}
|
||||
|
||||
/// Initial Event with load data
|
||||
class Load${upperName}Event extends ${upperName}Event {
|
||||
Load${upperName}Event({required this.id});
|
||||
final String? id;
|
||||
|
||||
static const String _name = 'Load${upperName}Event';
|
||||
|
||||
@override
|
||||
String toString() => _name;
|
||||
|
||||
@override
|
||||
Stream<${upperName}State> applyAsync({required ${upperName}Bloc bloc}) async* {
|
||||
// set loading true for show loading
|
||||
yield bloc.state.copyWithoutError(isLoading: true);
|
||||
// fetch data
|
||||
final result = await bloc.provider.fetchAsync(id);
|
||||
// set data to state
|
||||
yield bloc.state.copyWithoutError(
|
||||
isLoading: false,
|
||||
data: ${upperName}ViewModel(items: result),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
class Add${upperName}Event extends ${upperName}Event {
|
||||
static const String _name = 'Add${upperName}Event';
|
||||
|
||||
@override
|
||||
String toString() => _name;
|
||||
|
||||
@override
|
||||
Stream<${upperName}State> applyAsync({required ${upperName}Bloc bloc}) async* {
|
||||
yield bloc.state.copyWithoutError(isLoading: true);
|
||||
final result = await bloc.provider.addMore(bloc.state.data?.items);
|
||||
yield bloc.state.copyWithoutError(
|
||||
isLoading: false,
|
||||
data: ${upperName}ViewModel(items: result),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
class ErrorYouAwesomeEvent extends YouAwesomeEvent {
|
||||
static const String _name = 'ErrorYouAwesomeEvent';
|
||||
|
||||
@override
|
||||
String toString() => _name;
|
||||
|
||||
@override
|
||||
Stream<YouAwesomeState> applyAsync({required YouAwesomeBloc bloc}) async* {
|
||||
throw Exception('Test error');
|
||||
}
|
||||
}
|
||||
|
||||
class Clear${upperName}Event extends ${upperName}Event {
|
||||
static const String _name = 'Clear${upperName}Event';
|
||||
|
||||
@override
|
||||
String toString() => _name;
|
||||
|
||||
@override
|
||||
Stream<${upperName}State> applyAsync({required ${upperName}Bloc bloc}) async* {
|
||||
yield bloc.state.copyWithoutError(isLoading: true);
|
||||
yield bloc.state.copyWithoutData(
|
||||
isLoading: false,
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,51 +0,0 @@
|
||||
// ignore: depend_on_referenced_packages
|
||||
import 'package:equatable/equatable.dart';
|
||||
|
||||
class ${upperName}Model extends Equatable {
|
||||
const ${upperName}Model({
|
||||
required this.name,
|
||||
});
|
||||
final String name;
|
||||
|
||||
@override
|
||||
List<Object> get props => [ name];
|
||||
|
||||
Map<dynamic, dynamic> toMap() {
|
||||
return {
|
||||
'name': name,
|
||||
};
|
||||
}
|
||||
|
||||
static ${upperName}Model? fromMap(Map<dynamic, dynamic>? map) {
|
||||
if (map == null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return ${upperName}Model(
|
||||
name: map['name']!.toString(),
|
||||
);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
class ${upperName}ViewModel extends Equatable {
|
||||
const ${upperName}ViewModel({
|
||||
// TODO(all): add all required constructor parameters
|
||||
required this.items,
|
||||
});
|
||||
|
||||
// TODO(all): declare your fields here
|
||||
final List<${upperName}Model>? items;
|
||||
|
||||
@override
|
||||
List<Object?> get props => [items /*TODO(all): List all fields here*/];
|
||||
|
||||
// TODO(all): implement copyWith
|
||||
${upperName}ViewModel copyWith({
|
||||
List<${upperName}Model>? items,
|
||||
}) {
|
||||
return ${upperName}ViewModel(
|
||||
items: items ?? this.items,
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,57 +0,0 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
|
||||
class ${upperName}Page extends StatefulWidget {
|
||||
const ${upperName}Page({
|
||||
required this.bloc,
|
||||
super.key
|
||||
});
|
||||
static const String routeName = '/${privateName}';
|
||||
|
||||
final ${upperName}Bloc? bloc;
|
||||
|
||||
@override
|
||||
State<${upperName}Page> createState() => _${upperName}PageState();
|
||||
}
|
||||
|
||||
class _${upperName}PageState extends State<${upperName}Page> {
|
||||
|
||||
${upperName}Bloc? _bloc;
|
||||
${upperName}Bloc get bloc {
|
||||
// get it by DI in real code.
|
||||
_bloc ??= widget.bloc ?? ${upperName}Bloc();
|
||||
return _bloc!;
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
centerTitle: true,
|
||||
title: const Text('${upperName}'),
|
||||
actions: [
|
||||
IconButton(
|
||||
icon: const Icon(Icons.error),
|
||||
onPressed: () {
|
||||
bloc.add(ErrorYouAwesomeEvent());
|
||||
},
|
||||
),
|
||||
IconButton(
|
||||
icon: const Icon(Icons.add),
|
||||
onPressed: () {
|
||||
bloc.add(Add${upperName}Event());
|
||||
},
|
||||
),
|
||||
IconButton(
|
||||
icon: const Icon(Icons.clear),
|
||||
onPressed: () {
|
||||
bloc.add(Clear${upperName}Event());
|
||||
},
|
||||
),
|
||||
],
|
||||
),
|
||||
body: ${upperName}Screen(bloc: bloc),
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,26 +0,0 @@
|
||||
|
||||
import 'dart:async';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Provider {
|
||||
|
||||
Future<List<${upperName}Model>?> fetchAsync(String? id) async {
|
||||
// write logic here to send request to server
|
||||
if (id == null) {
|
||||
return null;
|
||||
}
|
||||
return [${upperName}Model(name: id)];
|
||||
}
|
||||
|
||||
|
||||
Future<List<${upperName}Model>?> addMore(List<${upperName}Model>? now) async {
|
||||
// write logic here to send request to server
|
||||
final result = [
|
||||
...(now ?? <${upperName}Model>[]),
|
||||
${upperName}Model(name: now?.length.toString() ?? '0')
|
||||
];
|
||||
return result;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -1,126 +0,0 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
|
||||
class ${upperName}Screen extends StatefulWidget {
|
||||
const ${upperName}Screen({
|
||||
required this.bloc,
|
||||
super.key,
|
||||
}) ;
|
||||
|
||||
@protected
|
||||
final ${upperName}Bloc bloc;
|
||||
|
||||
@override
|
||||
State<${upperName}Screen> createState() {
|
||||
return ${upperName}ScreenState();
|
||||
}
|
||||
}
|
||||
|
||||
class ${upperName}ScreenState extends State<${upperName}Screen> {
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
// load data on init widget if bloc has not data
|
||||
if (!widget.bloc.state.hasData) {
|
||||
_load();
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
// dispose bloc if you use subscriptions in bloc
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return BlocBuilder<${upperName}Bloc, ${upperName}State>(
|
||||
bloc: widget.bloc,
|
||||
builder: (
|
||||
BuildContext context,
|
||||
${upperName}State currentState,
|
||||
) {
|
||||
// declaration of bloc states
|
||||
return currentState.when(
|
||||
onLoading: ()=>const CircularProgressIndicator(),
|
||||
onEmpty: (data) => _Empty(),
|
||||
onData: (data) => _BodyList(data: data),
|
||||
onError: (e) => Center(
|
||||
child: Column(
|
||||
children: [
|
||||
Text(e.toString()),
|
||||
TextButton(
|
||||
onPressed: _load,
|
||||
child: const Text('ReLoad'),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
void _load() {
|
||||
widget.bloc.add(Load${upperName}Event(id:'1'));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
class _BodyList extends StatefulWidget {
|
||||
const _BodyList({required this.data});
|
||||
|
||||
final ${upperName}ViewModel data;
|
||||
|
||||
@override
|
||||
State<_BodyList> createState() => _BodyListState();
|
||||
}
|
||||
|
||||
class _BodyListState extends State<_BodyList> {
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
|
||||
return CustomScrollView(
|
||||
// primary: true,
|
||||
slivers: [
|
||||
const SliverToBoxAdapter(child: Divider()),
|
||||
SliverList(
|
||||
delegate: SliverChildBuilderDelegate(
|
||||
(BuildContext context, int index) {
|
||||
final item = widget.data.items![index];
|
||||
if (index == 0) {
|
||||
return Text('Header $index, id = '+item.name);
|
||||
}
|
||||
return Text('Index = $index, id = '+item.name);
|
||||
},
|
||||
childCount: widget.data.items!.length,
|
||||
))]);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
class _Empty extends StatelessWidget {
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Column(
|
||||
children: <Widget>[
|
||||
Text('Empty'),
|
||||
],
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
import 'package:ff_bloc/ff_bloc.dart';
|
||||
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}State extends FFState<${upperName}State, ${upperName}ViewModel> {
|
||||
const ${upperName}State({
|
||||
super.version = 0,
|
||||
super.isLoading = false,
|
||||
super.data,
|
||||
super.error,
|
||||
});
|
||||
|
||||
@override
|
||||
StateCopyFactory<${upperName}State, ${upperName}ViewModel> getCopyFactory() => ${upperName}State.new;
|
||||
}
|
||||
@@ -1,37 +0,0 @@
|
||||
import 'dart:async';
|
||||
import 'dart:developer' as developer;
|
||||
|
||||
import 'package:bloc/bloc.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Bloc extends Bloc<${upperName}Event, ${upperName}State> {
|
||||
// todo: check singleton for logic in project
|
||||
// use GetIt for DI in projct
|
||||
static final ${upperName}Bloc _${privateName}BlocSingleton = ${upperName}Bloc._internal();
|
||||
factory ${upperName}Bloc() {
|
||||
return _${privateName}BlocSingleton;
|
||||
}
|
||||
|
||||
${upperName}Bloc._internal(): super(Un${upperName}State(0)){
|
||||
on<${upperName}Event>((event, emit) {
|
||||
return emit.forEach<${upperName}State>(
|
||||
event.applyAsync(currentState: state, bloc: this),
|
||||
onData: (state) => state,
|
||||
onError: (error, stackTrace) {
|
||||
developer.log('$error', name: '${upperName}Bloc', error: error, stackTrace: stackTrace);
|
||||
return Error${upperName}State(0, error.toString());
|
||||
},
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> close() async{
|
||||
// dispose objects
|
||||
await super.close();
|
||||
}
|
||||
|
||||
@override
|
||||
${upperName}State get initialState => Un${upperName}State(0);
|
||||
|
||||
}
|
||||
@@ -1,42 +0,0 @@
|
||||
import 'dart:async';
|
||||
import 'dart:developer' as developer;
|
||||
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
import 'package:meta/meta.dart';
|
||||
|
||||
@immutable
|
||||
abstract class ${upperName}Event {
|
||||
Stream<${upperName}State> applyAsync(
|
||||
{${upperName}State currentState, ${upperName}Bloc bloc});
|
||||
final ${upperName}Repository _${privateName}Repository = ${upperName}Repository();
|
||||
}
|
||||
|
||||
class Un${upperName}Event extends ${upperName}Event {
|
||||
@override
|
||||
Stream<${upperName}State> applyAsync({${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
||||
yield Un${upperName}State(0);
|
||||
}
|
||||
}
|
||||
|
||||
class Load${upperName}Event extends ${upperName}Event {
|
||||
|
||||
final bool isError;
|
||||
@override
|
||||
String toString() => 'Load${upperName}Event';
|
||||
|
||||
Load${upperName}Event(this.isError);
|
||||
|
||||
@override
|
||||
Stream<${upperName}State> applyAsync(
|
||||
{${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
||||
try {
|
||||
yield Un${upperName}State(0);
|
||||
await Future.delayed(const Duration(seconds: 1));
|
||||
_${privateName}Repository.test(isError);
|
||||
yield In${upperName}State(0, 'Hello world');
|
||||
} catch (_, stackTrace) {
|
||||
developer.log('$_', name: 'Load${upperName}Event', error: _, stackTrace: stackTrace);
|
||||
yield Error${upperName}State(0, _.toString());
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,47 +0,0 @@
|
||||
import 'package:equatable/equatable.dart';
|
||||
|
||||
/// generate by https://javiercbk.github.io/json_to_dart/
|
||||
class Autogenerated${upperName} {
|
||||
final List<${upperName}Model> results;
|
||||
|
||||
Autogenerated${upperName}({required this.results});
|
||||
|
||||
factory Autogenerated${upperName}.fromJson(Map<String, dynamic> json) {
|
||||
var temp = <YouAwesomeModel>[];
|
||||
if (json['results'] != null) {
|
||||
temp = <${upperName}Model>[];
|
||||
json['results'].forEach((v) {
|
||||
temp.add(${upperName}Model.fromJson(v as Map<String, dynamic>));
|
||||
});
|
||||
}
|
||||
return Autogenerated${upperName}(results: temp);
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final data = <String, dynamic>{};
|
||||
data['results'] = results.map((v) => v.toJson()).toList();
|
||||
return data;
|
||||
}
|
||||
}
|
||||
|
||||
class ${upperName}Model extends Equatable {
|
||||
final int id;
|
||||
final String name;
|
||||
|
||||
${upperName}Model(this.id, this.name);
|
||||
|
||||
@override
|
||||
List<Object> get props => [id, name];
|
||||
|
||||
factory ${upperName}Model.fromJson(Map<String, dynamic> json) {
|
||||
return ${upperName}Model(json['id'] as int, json['name'] as String);
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final data = <String, dynamic>{};
|
||||
data['id'] = id;
|
||||
data['name'] = name;
|
||||
return data;
|
||||
}
|
||||
|
||||
}
|
||||
@@ -1,23 +0,0 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Page extends StatefulWidget {
|
||||
static const String routeName = '/${privateName}';
|
||||
|
||||
@override
|
||||
_${upperName}PageState createState() => _${upperName}PageState();
|
||||
}
|
||||
|
||||
class _${upperName}PageState extends State<${upperName}Page> {
|
||||
final _${privateName}Bloc = ${upperName}Bloc();
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
title: Text('${upperName}'),
|
||||
),
|
||||
body: ${upperName}Screen(${privateName}Bloc: _${privateName}Bloc),
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,20 +0,0 @@
|
||||
import 'dart:async';
|
||||
|
||||
class ${upperName}Provider {
|
||||
Future<void> loadAsync(String token) async {
|
||||
/// write from keystore/keychain
|
||||
await Future.delayed(Duration(seconds: 2));
|
||||
}
|
||||
|
||||
Future<void> saveAsync(String token) async {
|
||||
/// write from keystore/keychain
|
||||
await Future.delayed(Duration(seconds: 2));
|
||||
}
|
||||
|
||||
void test(bool isError) {
|
||||
if (isError == true){
|
||||
throw Exception('manual error');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,11 +0,0 @@
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Repository {
|
||||
final ${upperName}Provider _${privateName}Provider = ${upperName}Provider();
|
||||
|
||||
${upperName}Repository();
|
||||
|
||||
void test(bool isError) {
|
||||
_${privateName}Provider.test(isError);
|
||||
}
|
||||
}
|
||||
@@ -1,97 +0,0 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Screen extends StatefulWidget {
|
||||
const ${upperName}Screen({
|
||||
required ${upperName}Bloc ${privateName}Bloc,
|
||||
Key? key,
|
||||
}) : _${privateName}Bloc = ${privateName}Bloc,
|
||||
super(key: key);
|
||||
|
||||
final ${upperName}Bloc _${privateName}Bloc;
|
||||
|
||||
@override
|
||||
${upperName}ScreenState createState() {
|
||||
return ${upperName}ScreenState();
|
||||
}
|
||||
}
|
||||
|
||||
class ${upperName}ScreenState extends State<${upperName}Screen> {
|
||||
${upperName}ScreenState();
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
_load();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return BlocBuilder<${upperName}Bloc, ${upperName}State>(
|
||||
bloc: widget._${privateName}Bloc,
|
||||
builder: (
|
||||
BuildContext context,
|
||||
${upperName}State currentState,
|
||||
) {
|
||||
if (currentState is Un${upperName}State) {
|
||||
return Center(
|
||||
child: CircularProgressIndicator(),
|
||||
);
|
||||
}
|
||||
if (currentState is Error${upperName}State) {
|
||||
return Center(
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: <Widget>[
|
||||
Text(currentState.errorMessage),
|
||||
Padding(
|
||||
padding: const EdgeInsets.only(top: 32.0),
|
||||
child: ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
backgroundColor: Colors.blue,
|
||||
),
|
||||
child: Text('reload'),
|
||||
onPressed: _load,
|
||||
),
|
||||
),
|
||||
],
|
||||
));
|
||||
}
|
||||
if (currentState is In${upperName}State) {
|
||||
return Center(
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: <Widget>[
|
||||
Text(currentState.hello),
|
||||
const Text('Flutter files: done'),
|
||||
Padding(
|
||||
padding: const EdgeInsets.only(top: 32.0),
|
||||
child: ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
backgroundColor: Colors.red,
|
||||
),
|
||||
child: Text('throw error'),
|
||||
onPressed: () => _load(true),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
return Center(
|
||||
child: CircularProgressIndicator(),
|
||||
);
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
void _load([bool isError = false]) {
|
||||
widget._${privateName}Bloc.add(Load${upperName}Event(isError));
|
||||
}
|
||||
}
|
||||
@@ -1,83 +0,0 @@
|
||||
import 'package:equatable/equatable.dart';
|
||||
|
||||
abstract class ${upperName}State extends Equatable {
|
||||
${upperName}State(this.version);
|
||||
|
||||
/// notify change state without deep clone state
|
||||
final int version;
|
||||
|
||||
/// Copy object for use in action
|
||||
/// if need use deep clone
|
||||
${upperName}State getStateCopy();
|
||||
|
||||
${upperName}State getNewVersion();
|
||||
|
||||
@override
|
||||
List<Object> get props => [version];
|
||||
}
|
||||
|
||||
/// UnInitialized
|
||||
class Un${upperName}State extends ${upperName}State {
|
||||
|
||||
Un${upperName}State(int version) : super(version);
|
||||
|
||||
@override
|
||||
String toString() => 'Un${upperName}State';
|
||||
|
||||
@override
|
||||
Un${upperName}State getStateCopy() {
|
||||
return Un${upperName}State(0);
|
||||
}
|
||||
|
||||
@override
|
||||
Un${upperName}State getNewVersion() {
|
||||
return Un${upperName}State(version+1);
|
||||
}
|
||||
}
|
||||
|
||||
/// Initialized
|
||||
class In${upperName}State extends ${upperName}State {
|
||||
|
||||
In${upperName}State(int version, this.hello) : super(version);
|
||||
|
||||
final String hello;
|
||||
|
||||
@override
|
||||
String toString() => 'In${upperName}State $hello';
|
||||
|
||||
@override
|
||||
In${upperName}State getStateCopy() {
|
||||
return In${upperName}State(version, hello);
|
||||
}
|
||||
|
||||
@override
|
||||
In${upperName}State getNewVersion() {
|
||||
return In${upperName}State(version+1, hello);
|
||||
}
|
||||
|
||||
@override
|
||||
List<Object> get props => [version, hello];
|
||||
}
|
||||
|
||||
class Error${upperName}State extends ${upperName}State {
|
||||
Error${upperName}State(int version, this.errorMessage): super(version);
|
||||
|
||||
final String errorMessage;
|
||||
|
||||
@override
|
||||
String toString() => 'Error${upperName}State';
|
||||
|
||||
@override
|
||||
Error${upperName}State getStateCopy() {
|
||||
return Error${upperName}State(version, errorMessage);
|
||||
}
|
||||
|
||||
@override
|
||||
Error${upperName}State getNewVersion() {
|
||||
return Error${upperName}State(version+1,
|
||||
errorMessage);
|
||||
}
|
||||
|
||||
@override
|
||||
List<Object> get props => [version, errorMessage];
|
||||
}
|
||||
@@ -1,33 +0,0 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:navme/navme.dart';
|
||||
import 'package:navme/helpers.dart';
|
||||
|
||||
import 'index.dart';
|
||||
|
||||
class ${upperName}Navigate {
|
||||
// base path
|
||||
static String path = '${privateName}';
|
||||
|
||||
// config for configurate Router
|
||||
static RouteConfig routeConfig = RouteConfig(
|
||||
state: (Uri? uri) => RouteState(uri: path.toUri()),
|
||||
// condition for using this page
|
||||
isThisPage: (RouteState state) {
|
||||
if (state?.firstPath == path) {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
// settigs from url
|
||||
settings: (RouteState state) {
|
||||
return null;
|
||||
},
|
||||
// get Page for Router
|
||||
page: ({RouteState? state}) {
|
||||
return MaterialPage(
|
||||
key: const ValueKey('${upperName}Page'),
|
||||
child: ${upperName}Page(),
|
||||
name: '${upperName}Page');
|
||||
},
|
||||
);
|
||||
}
|
||||
@@ -1,21 +0,0 @@
|
||||
import 'dart:async';
|
||||
import 'dart:developer' as developer;
|
||||
|
||||
import 'package:bloc/bloc.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Bloc extends Bloc<${upperName}Event, ${upperName}State> {
|
||||
|
||||
${upperName}Bloc(${upperName}State initialState) : super(initialState){
|
||||
on<${upperName}Event>((event, emit) {
|
||||
return emit.forEach<${upperName}State>(
|
||||
event.applyAsync(currentState: state, bloc: this),
|
||||
onData: (state) => state,
|
||||
onError: (error, stackTrace) {
|
||||
developer.log('$error', name: '${upperName}Bloc', error: error, stackTrace: stackTrace);
|
||||
return Error${upperName}State(error.toString());
|
||||
},
|
||||
);
|
||||
});
|
||||
}
|
||||
}
|
||||
@@ -1,34 +0,0 @@
|
||||
import 'dart:async';
|
||||
import 'dart:developer' as developer;
|
||||
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
import 'package:meta/meta.dart';
|
||||
|
||||
@immutable
|
||||
abstract class ${upperName}Event {
|
||||
Stream<${upperName}State> applyAsync(
|
||||
{${upperName}State currentState, ${upperName}Bloc bloc});
|
||||
}
|
||||
|
||||
class Un${upperName}Event extends ${upperName}Event {
|
||||
@override
|
||||
Stream<${upperName}State> applyAsync({${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
||||
yield Un${upperName}State();
|
||||
}
|
||||
}
|
||||
|
||||
class Load${upperName}Event extends ${upperName}Event {
|
||||
|
||||
@override
|
||||
Stream<${upperName}State> applyAsync(
|
||||
{${upperName}State? currentState, ${upperName}Bloc? bloc}) async* {
|
||||
try {
|
||||
yield Un${upperName}State();
|
||||
await Future.delayed(const Duration(seconds: 1));
|
||||
yield In${upperName}State('Hello world');
|
||||
} catch (_, stackTrace) {
|
||||
developer.log('$_', name: 'Load${upperName}Event', error: _, stackTrace: stackTrace);
|
||||
yield Error${upperName}State( _.toString());
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,13 +0,0 @@
|
||||
import 'package:equatable/equatable.dart';
|
||||
|
||||
/// use https://marketplace.visualstudio.com/items?itemName=BendixMa.dart-data-class-generator
|
||||
class ${upperName}Model extends Equatable {
|
||||
final int id;
|
||||
final String name;
|
||||
|
||||
${upperName}Model(this.id, this.name);
|
||||
|
||||
@override
|
||||
List<Object> get props => [id, name];
|
||||
|
||||
}
|
||||
@@ -1,23 +0,0 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Page extends StatefulWidget {
|
||||
static const String routeName = '/${privateName}';
|
||||
|
||||
@override
|
||||
_${upperName}PageState createState() => _${upperName}PageState();
|
||||
}
|
||||
|
||||
class _${upperName}PageState extends State<${upperName}Page> {
|
||||
final _${privateName}Bloc = ${upperName}Bloc(Un${upperName}State());
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
title: Text('${upperName}'),
|
||||
),
|
||||
body: ${upperName}Screen(${privateName}Bloc: _${privateName}Bloc),
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,20 +0,0 @@
|
||||
import 'dart:async';
|
||||
|
||||
class ${upperName}Provider {
|
||||
Future<void> loadAsync(String token) async {
|
||||
/// write from keystore/keychain
|
||||
await Future.delayed(Duration(seconds: 2));
|
||||
}
|
||||
|
||||
Future<void> saveAsync(String token) async {
|
||||
/// write from keystore/keychain
|
||||
await Future.delayed(Duration(seconds: 2));
|
||||
}
|
||||
|
||||
void test(bool isError) {
|
||||
if (isError == true){
|
||||
throw Exception('manual error');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,11 +0,0 @@
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Repository {
|
||||
final ${upperName}Provider _${privateName}Provider = ${upperName}Provider();
|
||||
|
||||
${upperName}Repository();
|
||||
|
||||
void test(bool isError) {
|
||||
_${privateName}Provider.test(isError);
|
||||
}
|
||||
}
|
||||
@@ -1,84 +0,0 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||
import 'package:${appName}${relative}/index.dart';
|
||||
|
||||
class ${upperName}Screen extends StatefulWidget {
|
||||
const ${upperName}Screen({
|
||||
required ${upperName}Bloc ${privateName}Bloc,
|
||||
Key? key,
|
||||
}) : _${privateName}Bloc = ${privateName}Bloc,
|
||||
super(key: key);
|
||||
|
||||
final ${upperName}Bloc _${privateName}Bloc;
|
||||
|
||||
@override
|
||||
${upperName}ScreenState createState() {
|
||||
return ${upperName}ScreenState();
|
||||
}
|
||||
}
|
||||
|
||||
class ${upperName}ScreenState extends State<${upperName}Screen> {
|
||||
${upperName}ScreenState();
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
_load();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return BlocBuilder<${upperName}Bloc, ${upperName}State>(
|
||||
bloc: widget._${privateName}Bloc,
|
||||
builder: (
|
||||
BuildContext context,
|
||||
${upperName}State currentState,
|
||||
) {
|
||||
if (currentState is Un${upperName}State) {
|
||||
return Center(
|
||||
child: CircularProgressIndicator(),
|
||||
);
|
||||
}
|
||||
if (currentState is Error${upperName}State) {
|
||||
return Center(
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: <Widget>[
|
||||
Text(currentState.errorMessage ),
|
||||
Padding(
|
||||
padding: const EdgeInsets.only(top: 32.0),
|
||||
child: RaisedButton(
|
||||
color: Colors.blue,
|
||||
child: Text('reload'),
|
||||
onPressed: _load,
|
||||
),
|
||||
),
|
||||
],
|
||||
));
|
||||
}
|
||||
if (currentState is In${upperName}State) {
|
||||
return Center(
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: <Widget>[
|
||||
Text(currentState.hello),
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
return Center(
|
||||
child: CircularProgressIndicator(),
|
||||
);
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
void _load() {
|
||||
widget._${privateName}Bloc.add(Load${upperName}Event());
|
||||
}
|
||||
}
|
||||
@@ -1,42 +0,0 @@
|
||||
import 'package:equatable/equatable.dart';
|
||||
|
||||
abstract class ${upperName}State extends Equatable {
|
||||
${upperName}State();
|
||||
|
||||
@override
|
||||
List<Object> get props => [];
|
||||
}
|
||||
|
||||
/// UnInitialized
|
||||
class Un${upperName}State extends ${upperName}State {
|
||||
|
||||
Un${upperName}State();
|
||||
|
||||
@override
|
||||
String toString() => 'Un${upperName}State';
|
||||
}
|
||||
|
||||
/// Initialized
|
||||
class In${upperName}State extends ${upperName}State {
|
||||
In${upperName}State(this.hello);
|
||||
|
||||
final String hello;
|
||||
|
||||
@override
|
||||
String toString() => 'In${upperName}State $hello';
|
||||
|
||||
@override
|
||||
List<Object> get props => [hello];
|
||||
}
|
||||
|
||||
class Error${upperName}State extends ${upperName}State {
|
||||
Error${upperName}State(this.errorMessage);
|
||||
|
||||
final String errorMessage;
|
||||
|
||||
@override
|
||||
String toString() => 'Error${upperName}State';
|
||||
|
||||
@override
|
||||
List<Object> get props => [errorMessage];
|
||||
}
|
||||
Reference in New Issue
Block a user