Я работаю над очень простым проектом для моего школьного задания. Итак, это сайт по аренде жилья. Кажется, все в порядке, но я хочу автоматически создать счет типа «INV0001», но я не знаю, как это сделать. Может быть, вы, ребята, можете помочь мне починить мой контроллер
это мой контроллер
public function storeSewa(Request $request){
if ($request->edit=='false') {
$newdata = new Sewa;
} else {
$newdata = Sewa::find($request->id);
if ($newdata) {
//
}else {
$newdata = new Sewa;}}
$newdata->invoice = 'INV/'//idk, how?
$newdata->penyewa_id = $request->penyewa_id;
$newdata->kamar_id = $request->kamar_id;
$newdata->tanggal_masuk = $request->tanggal_masuk;
$newdata->tanggal_keluar = $request->tanggal_keluar;
$newdata->durasi = $request->durasi;
$newdata->status = 'Belum Lunas';
$newdata->save();
if ($newdata) {
session()->flash('status', 'Task was successful!');
session()->flash('type', 'success');
return Redirect::route('account');
}
return 'false';
}
Ну, я очень новичок в laravel, так что кто-нибудь может помочь решить мою проблему самым простым способом?
если вы используете базу данных, вы можете использовать автоматическое увеличение sql, для этой функции вы должны иметь эту строку в миграции моделей счетов:
Schema::create('invoices', function (Blueprint $table) {
$table->Increments('id');
});
если вы хотите, чтобы ваши номера счетов не были похожи на 1,2,3,... вы можете использовать такие библиотеки:
https://github.com/oanhnn/laravel-fakeid
если вы используете для теста, вы можете использовать фабрику подделок: здесь есть учебник:
https://www.codermen.com/blog/75/how-to-use-faker-with-laravel-5-7-tutorial