Skip to content

Commit 95bf9a7

Browse files
authored
Merge branch 'develop' into flutter/localization
2 parents db4b443 + d16f489 commit 95bf9a7

6 files changed

Lines changed: 436 additions & 112 deletions

File tree

data/adb.json

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -53,13 +53,29 @@
5353
"definition": "অ্যাপ ইন্সটল করা",
5454
"code": "adb install <apk-লোকেশন>"
5555
},
56+
{
57+
"definition": "ডিভাইস থেকে অ্যাপ রিমুভ করা",
58+
"code": "adb uninstall package-name"
59+
},
5660
{
5761
"definition": "লগ",
5862
"code": "adb logcat [অপশন] [ফিল্টার] [ফিল্টার] ..."
5963
},
6064
{
6165
"definition": "চলন্ত অ্যাপের লগ",
6266
"code": "adb logcat AndroidRuntime:E *:S\""
67+
},
68+
{
69+
"definition": "ফাইল ডাউনলোড করা",
70+
"code": "adb pull /sdcard/file-name"
71+
},
72+
{
73+
"definition": "ফাইল আপলোড করা",
74+
"code": "adb push file-name /sdcard/"
75+
},
76+
{
77+
"definition": "ফ্ল্যাশাবল জিপ ফাইল ফ্ল্যাশ করা",
78+
"code": "adb sideload filename.zip"
6379
}
6480
]
6581
},

data/dart.json

Lines changed: 13 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -150,7 +150,7 @@
150150
{
151151
"definition": "একটি স্ট্রিং খালি কিনা",
152152
"code": "''.isEmpty"
153-
}
153+
},
154154
{
155155
"definition": "একটি স্ট্রিং এ ভ্যালু আছে",
156156
"code": "''.isNotEmpty"
@@ -480,35 +480,39 @@
480480
"items": [
481481
{
482482
"definition": "প্রোজেক্টের সবগুলো প্যাকেজ ডাউনলোড করা",
483-
"code": "pub get"
483+
"code": "dart pub get"
484484
},
485485
{
486486
"definition": "লোকাল ক্যাশ থেকে প্যাকেজ সংযুক্ত করা",
487-
"code": "pub get --offline"
487+
"code": "dart pub get --offline"
488488
},
489489
{
490490
"definition": "লোকাল ক্যাশে একটি প্যাকেজ সংযুক্ত করা",
491-
"code": "pub cache add <প্যাকেজের নাম> --version \"<প্যাকেজের ভার্সন>\""
491+
"code": "dart pub cache add <প্যাকেজের নাম> --version \"<প্যাকেজের ভার্সন>\""
492+
},
493+
{
494+
"definition": "সিস্টেম ক্যাশে সমস্ত প্যাকেজ পুনরায় ইনস্টল করতে",
495+
"code": "dart pub cache repair"
492496
},
493497
{
494-
"definition": "সম্পাদনার কারণে প্যাকেজ মেরামতের জন্য পুনরায় ইনস্টল করা",
495-
"code": "pub cache repair"
498+
"definition": "সিস্টেম ক্যাশ রিমুভ করতে",
499+
"code": "dart pub cache clean"
496500
},
497501
{
498502
"definition": "ব্যবহৃত প্যাকেজগুলোকে ট্রি আকারে প্রিন্ট করা",
499503
"code": "pub deps"
500504
},
501505
{
502506
"definition": "ব্যবহৃত কোনো প্যাকেজের নতুন ভার্সন এসেছে কিনা খুঁজে দেখা",
503-
"code": "pub outdated"
507+
"code": "dart pub outdated"
504508
},
505509
{
506510
"definition": "ব্যবহৃত প্যাকেজগুলোকে নতুন ভার্সনে আপগ্রেড করা",
507-
"code": "pub upgrade"
511+
"code": "dart pub upgrade"
508512
},
509513
{
510514
"definition": "সার্বজনীন উপলব্ধ প্যাকেজ সচল করা",
511-
"code": "pub global activate <প্যাকেজের নাম>"
515+
"code": "dart pub global activate <প্যাকেজের নাম>"
512516
}
513517
]
514518
},

data/flutter.json

Lines changed: 163 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -43,6 +43,14 @@
4343
{
4444
"definition": "অর্গানাইজেশন/প্রতিষ্ঠানের নাম সেট করতে",
4545
"code": "flutter create --org com.yourorg your_project"
46+
},
47+
{
48+
"definition": "প্রোজেক্ট টেম্পলেট সেট করতে",
49+
"code": "flutter create --template=(app|package|plugin|module) <project_name>"
50+
},
51+
{
52+
"definition": "পূর্বে এক্সপোর্টকৃত ফাইলসমূহ ডিলিট করতে",
53+
"code": "flutter clean"
4654
}
4755
]
4856
},
@@ -143,6 +151,18 @@
143151
"code": "”fvm flutter pub get”, “fvm flutter run”"
144152
},
145153
{
154+
"definition": "FVM ভার্সন ^3.0.0 আপগ্রেড",
155+
"code": "FVM এর নতুন ভার্সনগুলোতে বেশ কিছু চেইঞ্জ এসেছে। \n প্রথমেই প্রজেক্টের টার্মিনালে dart pub global activate fvm রান করুন। এতে আপনার মেশিনের FVM, লেটেস্ট ভার্সনে আপডেট হয়ে যাবে।"
156+
},
157+
{
158+
"definition": "FVM v^3.0.0 এর কনফিগ",
159+
"code": "ভার্সন ^3.0.0 এর পর থেকে আগের .fvm ফোল্ডারটির সাথেসাথে প্রজেক্টের রুট-এ .fvmrc ফাইল তৈরি হবে। এতে প্রোজেক্ট স্পেসিফিক কনফিগারেশনের ইনফরমেশন থাকবে।"
160+
},
161+
{
162+
"definition": "FVM v^3.0.0 এর সুবিধা",
163+
"code": "ভার্সন ^3.0.0 এর থেকে, ফ্লাটারের ব্যাসিক কমান্ডগুলোর জন্য আগের মতো শুরুতে fvm ব্যবহার না করলেও হবে। \n আগে: fvm flutter pub get \n এখন: flutter pub get"
164+
},
165+
{
146166
"definition": "অফিসিয়াল সাইট",
147167
"code": "https://fvm.app"
148168
}
@@ -330,7 +350,149 @@
330350
"code": "flutter gen-l10n"
331351
}
332352
]
333-
},
353+
},
354+
{
355+
"title": "ফ্লাটার WebRTC (Implementing WebRTC in Flutter)",
356+
"items": [
357+
{
358+
"definition": "WebRTC কি?",
359+
"code": "WebRTC হলো একটি ফ্রি এবং ওপেন সোর্স প্রজেক্ট। এটা দিয়ে খুব সহজেই, কোনো সার্ভার ছাড়াই ওয়েব ব্রাউজার বা মোবাইল অ্যাপে অডিও, ভিডিও কলের মতো রিয়েল টাইম কম্যুনিকেশন সেট করা যায়।"
360+
},
361+
{
362+
"definition": "WebRTC কানেকশনের ব্যাসিক আইডিয়া",
363+
"code": "WebRTC কনেকশনে ২টা peer (ডিভাইস) থাকে। একটা ইনিশিয়েটর(কল করে), অন্যটা রিসিভার(কল রিসিভ করে)। এই দুইটা ডিভাইসের মধ্যে কানেকশন তৈরি হতে হলে, উভয়ের ডিটেইলস(SDP, Ice Candidates) একে অন্যের কাছে পাঠাতে হবে। এইটাকে Signaling বলে।"
364+
},
365+
{
366+
"definition": "SDP (Session Description Protocol) কি?",
367+
"code": "সহজ ভাষায় SDP হলো একটি অবজেক্ট, যার ভিতরে দুইটা ডিভাইসের মধ্যে কানেকশন তৈরি করার জন্য প্রয়োজনীয় সব ইনফরমেশন থাকে।"
368+
},
369+
{
370+
"definition": "ICE (Interactive Connectivity Establishment) কি?",
371+
"code": "ICE হলো একটি প্রোটোকল, যার মাধ্যমে দুইটা ডিভাইসের মধ্যে কানেকশন তৈরি করা হয়।"
372+
},
373+
{
374+
"definition": "STUN (Session Traversal Utilities for NAT) কি?",
375+
"code": "দুইটা ডিভাইসের পাবলিক IP খুজে বের করার জন্য STUN সার্ভার ব্যবহার করা হয়।"
376+
},
377+
{
378+
"definition": "TURN (Traversal Using Relays around NAT) কি?",
379+
"code": "খুব সিকিউর কানেকশনে পাবলিক IP খুজে বের করার জন্য TURN সার্ভার ব্যবহার করা হয়।"
380+
},
381+
{
382+
"definition": "ফ্লাটারে কিভাবে WebRTC ইমপ্লিমেন্ট করবেন?",
383+
"code": "নেটিভ API ব্যবহার করে অথবা, Agora / ZegoCloud এর মতো বিল্টইন সলিউশন ব্যাবহার করে ফ্লাটারে WebRTC ইমপ্লিমেন্ট করা যায়।"
384+
},
385+
{
386+
"definition": "নেটিভ API ব্যবহার করে WebRTC ডিপেন্ডেন্সি যোগ করতে -",
387+
"code": "dependencies:\n flutter_webrtc: ^0.11.7"
388+
},
389+
{
390+
"definition": "androidmanifest.xml এ প্রয়োজনীয় পারমিশন যোগ করুন (Android)",
391+
"code": "<uses-feature android:name=\"android.hardware.camera\" />\n<uses-feature android:name=\"android.hardware.camera.autofocus\" />\n<uses-permission android:name=\"android.permission.CAMERA\" />\n<uses-permission android:name=\"android.permission.RECORD_AUDIO\" />\n<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\" />\n<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\" />\n<uses-permission android:name=\"android.permission.MODIFY_AUDIO_SETTINGS\" />"
392+
},
393+
{
394+
"definition": "প্রয়োজনীয় পারমিশন যোগ করুন (iOS)",
395+
"code": "<key>NSCameraUsageDescription</key>\n<string>Camera permission description</string>\n<key>NSMicrophoneUsageDescription</key>\n<string>Microphone permission description</string>"
396+
},
397+
{
398+
"definition": "RTCPeerConnection তৈরি করুন",
399+
"code": "final Map<String, dynamic> configuration = {\n 'iceServers': [\n {'urls': 'stun:stun.l.google.com:19302'},\n ]\n};\nfinal pc = await createPeerConnection(configuration);"
400+
},
401+
{
402+
"definition": "লোকাল মিডিয়া স্ট্রিম যোগ করুন",
403+
"code": "final Map<String, dynamic> mediaConstraints = {\n 'audio': true,\n 'video': {\n 'facingMode': 'user',\n }\n};\nMediaStream stream = await navigator.mediaDevices.getUserMedia(mediaConstraints);\nawait pc.addStream(stream);"
404+
},
405+
{
406+
"definition": "Offer তৈরি করুন",
407+
"code": "RTCSessionDescription offer = await pc.createOffer();\nawait pc.setLocalDescription(offer);\n// Send this offer to the remote peer via your signaling server"
408+
},
409+
{
410+
"definition": "Answer রিসিভ করুন",
411+
"code": "// Assume 'answer' is received from the remote peer\nawait pc.setRemoteDescription(answer);"
412+
},
413+
{
414+
"definition": "ICE Candidate পাঠান",
415+
"code": "pc.onIceCandidate = (candidate) {\n // Send this candidate to the remote peer via your signaling server\n};"
416+
},
417+
{
418+
"definition": "রিমোট স্ট্রিম রিসিভ করুন",
419+
"code": "pc.onAddStream = (stream) {\n // Use this stream to display video/play audio from remote peer\n};"
420+
},
421+
{
422+
"definition": "কানেকশন বন্ধ করুন",
423+
"code": "await pc.close();\nawait stream.dispose();"
424+
},
425+
{
426+
"definition": "WebRTC ডিবাগিং",
427+
"code": "// Enable debug logging\nwebrtc.debugger.enabled = true;\n\n// For more detailed logging\nwebrtc.debugger.onEvent.listen((e) {\n print(e);\n});"
428+
},
429+
{
430+
"definition": "WebRTC শেখার কিছু রিসোর্স",
431+
"code": "https://webrtc.org\nhttps://codelabs.developers.google.com/codelabs/webrtc-web\nhttps://www.w3.org/TR/webrtc\n\nhttps://pub.dev/packages/flutter_webrtc"
432+
}
433+
]
434+
},
435+
{
436+
"title": "Flutter টেস্টিং (Flutter Testing)",
437+
"items": [
438+
{
439+
"definition": "ফ্লাটারে ৩ ধরনের টেস্ট রান করা যায়",
440+
"code": "১. ইউনিট টেস্ট (Unit Test)\n২. উইজেট টেস্ট (Widget Test)\n৩. ইন্টিগ্রেশন টেস্ট (Integration Test)"
441+
},
442+
{
443+
"definition": "Unit Test কি?",
444+
"code": "কোনো একটা ফাংশন, মেথড বা ক্লাস টেস্ট করার জন্য ইউনিট টেস্ট ব্যবহার করা হয়।"
445+
},
446+
{
447+
"definition": "Widget Test কি?",
448+
"code": "উইজেট টেস্টিং হলো নির্দিষ্ট উইজেট বা উইজেটের কোনো পার্ট টেস্ট করা।"
449+
},
450+
{
451+
"definition": "Integration Test কি?",
452+
"code": "ইন্টিগ্রেশন টেস্টিং এর মাধ্যমে একটি এপের কমপ্লিট ফাংশনালিটি টেস্ট করা হয়। একে এন্ড টু এন্ড টেস্টও বলা হয়।"
453+
},
454+
{
455+
"definition": "টেস্টিং রিলেটেড প্যাকেজ যোগ করতে -",
456+
"code": "dev_dependencies:\n flutter_test:\n sdk: flutter\n integration_test:\n sdk: flutter\n mockito: ^5.0.0"
457+
},
458+
{
459+
"definition": "ইউনিট টেস্ট রান করতে -",
460+
"code": "flutter test test/unit_test.dart"
461+
},
462+
{
463+
"definition": "উইজেট টেস্ট রান করতে -",
464+
"code": "flutter test test/widget_test.dart"
465+
},
466+
{
467+
"definition": "ইন্টিগ্রেশন টেস্ট রান করতে -",
468+
"code": "flutter test integration_test/app_test.dart"
469+
},
470+
{
471+
"definition": "সকল টেস্ট রান করতে -",
472+
"code": "flutter test"
473+
},
474+
{
475+
"definition": "ইউনিট টেস্ট উদাহরণ",
476+
"code": "void main() {\n test('String.split() splits the string on the delimiter', () {\n var string = 'foo,bar,baz';\n expect(string.split(','), equals(['foo', 'bar', 'baz']));\n });\n}"
477+
},
478+
{
479+
"definition": "উইজেট টেস্ট উদাহরণ",
480+
"code": "void main() {\n testWidgets('MyWidget has a title and message', (WidgetTester tester) async {\n await tester.pumpWidget(MyWidget(title: 'T', message: 'M'));\n final titleFinder = find.text('T');\n final messageFinder = find.text('M');\n expect(titleFinder, findsOneWidget);\n expect(messageFinder, findsOneWidget);\n });\n}"
481+
},
482+
{
483+
"definition": "ইন্টিগ্রেশন টেস্ট উদাহরণ",
484+
"code": "void main() {\n IntegrationTestWidgetsFlutterBinding.ensureInitialized();\n testWidgets('tap on the floating action button, verify counter',\n (WidgetTester tester) async {\n app.main();\n await tester.pumpAndSettle();\n expect(find.text('0'), findsOneWidget);\n final Finder fab = find.byTooltip('Increment');\n await tester.tap(fab);\n await tester.pumpAndSettle();\n expect(find.text('1'), findsOneWidget);\n });\n}"
485+
},
486+
{
487+
"definition": "মক অবজেক্ট তৈরি করেন (Mockito ব্যবহার করে)",
488+
"code": "import 'package:mockito/mockito.dart';\n\nclass MockYourClass extends Mock implements YourClass {}\n\nvoid main() {\n final mock = MockYourClass();\n when(mock.someMethod()).thenReturn('mocked value');\n}"
489+
},
490+
{
491+
"definition": "টেস্ট কভারেজ রিপোর্ট জেনারেট করেন",
492+
"code": "flutter test --coverage\n# কভারেজ রিপোর্ট coverage/lcov.info ফাইলে জেনারেট হবে\n# HTML রিপোর্ট জেনারেট করতে lcov ইনস্টল করেন এবং নিচের কমান্ড চালান:\n# genhtml coverage/lcov.info -o coverage/html"
493+
}
494+
]
495+
},
334496
{
335497
"title": "কিছু ইম্পরট্যান্ট ফ্লাটার শীট",
336498
"items": [

0 commit comments

Comments
 (0)