mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-11 22:07:29 -08:00
parent
5d4920c741
commit
99f65cbf69
|
@ -426,6 +426,7 @@ class Asset extends Depreciable
|
||||||
{
|
{
|
||||||
$settings = \App\Models\Setting::getSettings();
|
$settings = \App\Models\Setting::getSettings();
|
||||||
|
|
||||||
|
|
||||||
if ($settings->auto_increment_assets == '1') {
|
if ($settings->auto_increment_assets == '1') {
|
||||||
$temp_asset_tag = \DB::table('assets')
|
$temp_asset_tag = \DB::table('assets')
|
||||||
->where('physical', '=', '1')
|
->where('physical', '=', '1')
|
||||||
|
@ -435,14 +436,43 @@ class Asset extends Depreciable
|
||||||
$asset_tag = preg_replace('/^0*/', '', $asset_tag_digits);
|
$asset_tag = preg_replace('/^0*/', '', $asset_tag_digits);
|
||||||
|
|
||||||
if ($settings->zerofill_count > 0) {
|
if ($settings->zerofill_count > 0) {
|
||||||
return $settings->auto_increment_prefix.Asset::zerofill(($asset_tag + 1), $settings->zerofill_count);
|
return $settings->auto_increment_prefix.Asset::zerofill($settings->next_auto_tag_base, $settings->zerofill_count);
|
||||||
}
|
}
|
||||||
return $settings->auto_increment_prefix.($asset_tag + 1);
|
return $settings->auto_increment_prefix.$settings->next_auto_tag_bas;
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the next base number for the auto-incrementer. We'll add the zerofill and
|
||||||
|
* prefixes on the fly as we generate the number
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public static function nextAutoIncrement($assets)
|
||||||
|
{
|
||||||
|
|
||||||
|
$max = 1;
|
||||||
|
|
||||||
|
foreach ($assets as $asset) {
|
||||||
|
$results = preg_match ( "/\d+$/" , $asset['asset_tag'], $matches);
|
||||||
|
|
||||||
|
if ($results)
|
||||||
|
{
|
||||||
|
$number = $matches[0];
|
||||||
|
|
||||||
|
if ($number > $max)
|
||||||
|
{
|
||||||
|
$max = $number;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $max + 1;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static function zerofill($num, $zerofill = 3)
|
public static function zerofill($num, $zerofill = 3)
|
||||||
{
|
{
|
||||||
|
@ -688,9 +718,9 @@ class Asset extends Depreciable
|
||||||
/**
|
/**
|
||||||
* Query builder scope to get accepted assets
|
* Query builder scope to get accepted assets
|
||||||
*
|
*
|
||||||
* @param Illuminate\Database\Query\Builder $query Query builder instance
|
* @param \Illuminate\Database\Query\Builder $query Query builder instance
|
||||||
*
|
*
|
||||||
* @return Illuminate\Database\Query\Builder Modified query builder
|
* @return \Illuminate\Database\Query\Builder Modified query builder
|
||||||
*/
|
*/
|
||||||
public function scopeAccepted($query)
|
public function scopeAccepted($query)
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use App\Models\Asset;
|
||||||
|
|
||||||
|
class AddNextAutoincrementToSettings extends Migration
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function up()
|
||||||
|
{
|
||||||
|
$assets = Asset::select('asset_tag')->whereNull('deleted_at')->get();
|
||||||
|
if (!$next = Asset::nextAutoIncrement($assets)) {
|
||||||
|
$next = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
Schema::table('settings', function (Blueprint $table) use ($next) {
|
||||||
|
$table->bigInteger('next_auto_tag_base')->nullable()->default(null);
|
||||||
|
});
|
||||||
|
|
||||||
|
\Log::debug('Setting '.$next.' as default auto-increment');
|
||||||
|
$settings = App\Models\Setting::first();
|
||||||
|
$settings->next_auto_tag_base = $next;
|
||||||
|
$settings->save();
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
Schema::table('settings', function ($table) {
|
||||||
|
$table->dropColumn('next_auto_tag_base');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
|
@ -51,6 +51,42 @@ class AssetTest extends \Codeception\TestCase\Test
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function testAutoIncrementMixed()
|
||||||
|
{
|
||||||
|
$expected = '123411';
|
||||||
|
$next = Asset::nextAutoIncrement(
|
||||||
|
collect([
|
||||||
|
['asset_tag' => '0012345'],
|
||||||
|
['asset_tag' => 'WTF00134'],
|
||||||
|
['asset_tag' => 'WTF-745'],
|
||||||
|
['asset_tag' => '0012346'],
|
||||||
|
['asset_tag' => '00123410'],
|
||||||
|
['asset_tag' => 'U8T7597h77']
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
\Log::debug(print_r($next));
|
||||||
|
$this->assertEquals($expected, $next);
|
||||||
|
}
|
||||||
|
|
||||||
|
// public function testAutoIncrementMixedFullTagNumber()
|
||||||
|
// {
|
||||||
|
// $expected = '123411';
|
||||||
|
// $next = Asset::nextAutoIncrement(
|
||||||
|
// [
|
||||||
|
// ['asset_tag' => '0012345'],
|
||||||
|
// ['asset_tag' => 'WTF00134'],
|
||||||
|
// ['asset_tag' => 'WTF-745'],
|
||||||
|
// ['asset_tag' => '0012346'],
|
||||||
|
// ['asset_tag' => '00123410'],
|
||||||
|
// ['asset_tag' => 'U8T7597h77']
|
||||||
|
// ]
|
||||||
|
// );
|
||||||
|
// $this->assertEquals($expected, $next);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in a new issue