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: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: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 {
|
try {
|
||||||
// Ambil parameter nomor dari URL
|
// Ambil parameter nomor dari URL
|
||||||
const { searchParams } = new URL(request.url);
|
const { nomor } = await request.json();
|
||||||
const nomor = searchParams.get("nomor");
|
|
||||||
|
|
||||||
// Validasi parameter nomor
|
// Validasi parameter nomor
|
||||||
if (!nomor) {
|
if (!nomor) {
|
||||||
@@ -27,6 +26,9 @@ async function DELETE(request: Request) {
|
|||||||
|
|
||||||
// Cek apakah data OTP dengan nomor tersebut ada
|
// Cek apakah data OTP dengan nomor tersebut ada
|
||||||
const existingOtp = await prisma.kodeOtp.findFirst({
|
const existingOtp = await prisma.kodeOtp.findFirst({
|
||||||
|
orderBy: {
|
||||||
|
createdAt: "desc",
|
||||||
|
},
|
||||||
where: { nomor },
|
where: { nomor },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -40,8 +40,12 @@ const apiDeleteAktivasiKodeOtpByNomor = async ({
|
|||||||
}: {
|
}: {
|
||||||
nomor: string;
|
nomor: string;
|
||||||
}) => {
|
}) => {
|
||||||
const respone = await fetch(`/api/auth/delete/${nomor}`, {
|
const respone = await fetch(`/api/auth/code`, {
|
||||||
method: "DELETE",
|
method: "DELETE",
|
||||||
|
body: JSON.stringify({nomor}),
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
return await respone.json().catch(() => null);
|
return await respone.json().catch(() => null);
|
||||||
|
|||||||
@@ -129,6 +129,7 @@ export const middleware = async (req: NextRequest) => {
|
|||||||
// ==================== Authentication: Login, Validasi, Registrasi ==================== //
|
// ==================== Authentication: Login, Validasi, Registrasi ==================== //
|
||||||
// Token verification
|
// Token verification
|
||||||
const user = await verifyToken({ token, encodedKey });
|
const user = await verifyToken({ token, encodedKey });
|
||||||
|
console.log("middlaware",user)
|
||||||
|
|
||||||
// Handle login page access
|
// Handle login page access
|
||||||
if (pathname === loginPath) {
|
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