delete file tamplate

This commit is contained in:
2025-02-05 11:49:09 +08:00
parent 0d515797f5
commit 331b5c9a84
36 changed files with 16 additions and 1110 deletions

View File

@@ -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"}

View File

@@ -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"}

View File

@@ -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 },
});

View File

@@ -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);

View File

@@ -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) {

View File

@@ -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"]
}
]
}
]
}

View File

@@ -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);
}

View File

@@ -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,
);
}
}

View File

@@ -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,
);
}
}

View File

@@ -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),
);
}
}

View File

@@ -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;
}
}

View File

@@ -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'),
],
);
}
}

View File

@@ -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;
}

View File

@@ -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);
}

View File

@@ -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());
}
}
}

View File

@@ -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;
}
}

View File

@@ -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),
);
}
}

View File

@@ -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');
}
}
}

View File

@@ -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);
}
}

View File

@@ -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));
}
}

View File

@@ -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];
}

View File

@@ -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');
},
);
}

View File

@@ -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());
},
);
});
}
}

View File

@@ -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());
}
}
}

View File

@@ -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];
}

View File

@@ -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),
);
}
}

View File

@@ -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');
}
}
}

View File

@@ -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);
}
}

View File

@@ -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());
}
}

View File

@@ -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];
}

1
x.sh
View File

@@ -1 +0,0 @@
# Test sh

View File

@@ -1,14 +0,0 @@
#!/bin/bash
ffmpeg -f avfoundation \
-i "1:0" \
-s 1280x720 \
-framerate 30 \
-c:v libx264 \
-preset ultrafast \
-tune zerolatency \
-b:v 3000k \
-c:a aac \
-b:a 192k \
-vf "format=uyvy422" \
-f flv "rtmp://192.168.1.243:1935/live/bagas" \
-probesize 10M