mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-12 22:37:28 -08:00
Fixed custom fields edit behavior with cutom format always selected
This commit is contained in:
parent
c0f791cf13
commit
cdfd720c65
|
@ -16,12 +16,17 @@ class CustomField extends Model
|
||||||
public static $PredefinedFormats=[
|
public static $PredefinedFormats=[
|
||||||
"ANY" => "",
|
"ANY" => "",
|
||||||
"ALPHA" => "alpha",
|
"ALPHA" => "alpha",
|
||||||
|
"ALPHA-DASH" => "alpha_dash",
|
||||||
|
"NUMERIC" => "numeric",
|
||||||
|
"ALPHA-NUMERIC" => "alpha_num",
|
||||||
"EMAIL" => "email",
|
"EMAIL" => "email",
|
||||||
"DATE" => "date",
|
"DATE" => "date",
|
||||||
"URL" => "url",
|
"URL" => "url",
|
||||||
"NUMERIC" => "numeric",
|
|
||||||
"MAC" => "regex:/^[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}$/",
|
|
||||||
"IP" => "ip",
|
"IP" => "ip",
|
||||||
|
"IPV4" => "ipv4",
|
||||||
|
"IPV6" => "ipv6",
|
||||||
|
"MAC" => "regex:/^[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}:[a-fA-F0-9]{2}$/",
|
||||||
|
"BOOLEAN" => "boolean",
|
||||||
];
|
];
|
||||||
|
|
||||||
public $rules = [
|
public $rules = [
|
||||||
|
@ -30,27 +35,54 @@ class CustomField extends Model
|
||||||
|
|
||||||
// This is confusing, since it's actually the custom fields table that
|
// This is confusing, since it's actually the custom fields table that
|
||||||
// we're usually modifying, but since we alter the assets table, we have to
|
// we're usually modifying, but since we alter the assets table, we have to
|
||||||
// say that here
|
// say that here, otherwise the new fields get added onto the custom fields
|
||||||
|
// table instead of the assets table.
|
||||||
public static $table_name = "assets";
|
public static $table_name = "assets";
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert the custom field's name property to a db-safe string.
|
||||||
|
*
|
||||||
|
* We could probably have used str_slug() here but not sure what it would
|
||||||
|
* do with previously existing values. - @snipe
|
||||||
|
*
|
||||||
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
||||||
|
* @since [v3.4]
|
||||||
|
* @return String
|
||||||
|
*/
|
||||||
public static function name_to_db_name($name)
|
public static function name_to_db_name($name)
|
||||||
{
|
{
|
||||||
return "_snipeit_" . preg_replace("/[^a-zA-Z0-9]/", "_", strtolower($name));
|
return "_snipeit_" . preg_replace("/[^a-zA-Z0-9]/", "_", strtolower($name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set some boot methods for creating and updating.
|
||||||
|
*
|
||||||
|
* There is never ever a time when we wouldn't want to be updating those asset
|
||||||
|
* column names and the values of the db column name in the custom fields table
|
||||||
|
* if they have changed, so we handle that here so that we don't have to remember
|
||||||
|
* to do it in the controllers.
|
||||||
|
*
|
||||||
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
||||||
|
* @since [v3.4]
|
||||||
|
* @return Boolean
|
||||||
|
*/
|
||||||
public static function boot()
|
public static function boot()
|
||||||
{
|
{
|
||||||
self::created(function ($custom_field) {
|
self::created(function ($custom_field) {
|
||||||
|
|
||||||
// column exists - nothing to do here
|
// Column already exists on the assets table - nothing to do here.
|
||||||
|
// This *shouldn't* happen in the wild.
|
||||||
if (Schema::hasColumn(CustomField::$table_name, $custom_field->convertUnicodeDbSlug())) {
|
if (Schema::hasColumn(CustomField::$table_name, $custom_field->convertUnicodeDbSlug())) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Update the column name in the assets table
|
||||||
Schema::table(CustomField::$table_name, function ($table) use ($custom_field) {
|
Schema::table(CustomField::$table_name, function ($table) use ($custom_field) {
|
||||||
$table->text($custom_field->convertUnicodeDbSlug())->nullable();
|
$table->text($custom_field->convertUnicodeDbSlug())->nullable();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Update the db_column property in the custom fields table
|
||||||
$custom_field->db_column = $custom_field->convertUnicodeDbSlug();
|
$custom_field->db_column = $custom_field->convertUnicodeDbSlug();
|
||||||
$custom_field->save();
|
$custom_field->save();
|
||||||
});
|
});
|
||||||
|
@ -58,8 +90,9 @@ class CustomField extends Model
|
||||||
|
|
||||||
self::updating(function ($custom_field) {
|
self::updating(function ($custom_field) {
|
||||||
|
|
||||||
// Column already exists. Nothing to update.
|
// Column already exists on the assets table - nothing to do here.
|
||||||
if ($custom_field->isDirty("name")) {
|
if ($custom_field->isDirty("name")) {
|
||||||
|
|
||||||
if (Schema::hasColumn(CustomField::$table_name, $custom_field->convertUnicodeDbSlug())) {
|
if (Schema::hasColumn(CustomField::$table_name, $custom_field->convertUnicodeDbSlug())) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -113,10 +146,21 @@ class CustomField extends Model
|
||||||
return $this->db_column;
|
return $this->db_column;
|
||||||
}
|
}
|
||||||
|
|
||||||
// mutators for 'format' attribute
|
/**
|
||||||
|
* Mutator for the 'format' attribute.
|
||||||
|
*
|
||||||
|
* This is used by the dropdown to store the laravel-specific
|
||||||
|
* validator strings in the database but still return the
|
||||||
|
* user-friendly text in the dropdowns, and in the custom fields display.
|
||||||
|
*
|
||||||
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
||||||
|
* @since [v3.4]
|
||||||
|
* @return Array
|
||||||
|
*/
|
||||||
public function getFormatAttribute($value)
|
public function getFormatAttribute($value)
|
||||||
{
|
{
|
||||||
foreach (self::$PredefinedFormats as $name => $pattern) {
|
foreach (self::$PredefinedFormats as $name => $pattern) {
|
||||||
|
\Log::debug($name.'=>'.$pattern);
|
||||||
if ($pattern === $value) {
|
if ($pattern === $value) {
|
||||||
return $name;
|
return $name;
|
||||||
}
|
}
|
||||||
|
@ -168,6 +212,13 @@ class CustomField extends Model
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check whether the field is encrypted
|
||||||
|
*
|
||||||
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
||||||
|
* @since [v3.4]
|
||||||
|
* @return Boolean
|
||||||
|
*/
|
||||||
public function isFieldDecryptable($string)
|
public function isFieldDecryptable($string)
|
||||||
{
|
{
|
||||||
if (($this->field_encrypted=='1') && ($string!='')) {
|
if (($this->field_encrypted=='1') && ($string!='')) {
|
||||||
|
@ -177,6 +228,14 @@ class CustomField extends Model
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert non-UTF-8 or weirdly encoded text into something that
|
||||||
|
* won't break the database.
|
||||||
|
*
|
||||||
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
||||||
|
* @since [v3.4]
|
||||||
|
* @return Boolean
|
||||||
|
*/
|
||||||
public function convertUnicodeDbSlug($original = null)
|
public function convertUnicodeDbSlug($original = null)
|
||||||
{
|
{
|
||||||
$name = $original ? $original : $this->name;
|
$name = $original ? $original : $this->name;
|
||||||
|
|
|
@ -28,7 +28,6 @@
|
||||||
|
|
||||||
<div class="box box-default">
|
<div class="box box-default">
|
||||||
<div class="box-body">
|
<div class="box-body">
|
||||||
|
|
||||||
<!-- Name -->
|
<!-- Name -->
|
||||||
<div class="form-group {{ $errors->has('name') ? ' has-error' : '' }}">
|
<div class="form-group {{ $errors->has('name') ? ' has-error' : '' }}">
|
||||||
<label for="name" class="col-md-4 control-label">
|
<label for="name" class="col-md-4 control-label">
|
||||||
|
@ -71,7 +70,7 @@
|
||||||
{{ trans('admin/custom_fields/general.field_format') }}
|
{{ trans('admin/custom_fields/general.field_format') }}
|
||||||
</label>
|
</label>
|
||||||
<div class="col-md-6 required">
|
<div class="col-md-6 required">
|
||||||
{{ Form::select("format",\App\Helpers\Helper::predefined_formats(),"ANY", array('class'=>'format select2 form-control')) }}
|
{{ Form::select("format",\App\Helpers\Helper::predefined_formats(), $field->format, array('class'=>'format select2 form-control')) }}
|
||||||
{!! $errors->first('format', '<span class="alert-msg"><i class="fa fa-times"></i> :message</span>') !!}
|
{!! $errors->first('format', '<span class="alert-msg"><i class="fa fa-times"></i> :message</span>') !!}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -82,10 +81,12 @@
|
||||||
{{ trans('admin/custom_fields/general.field_custom_format') }}
|
{{ trans('admin/custom_fields/general.field_custom_format') }}
|
||||||
</label>
|
</label>
|
||||||
<div class="col-md-6 required">
|
<div class="col-md-6 required">
|
||||||
{{ Form::text('custom_format', Input::old('custom_format', (($field->format!='') && ($field->format!='ANY')) ? $field->format : ''), array('class' => 'form-control', 'id' => 'custom_format', 'placeholder'=>'regex:/^[0-9]{15}$/')) }}
|
|
||||||
|
{{ Form::text('custom_format', Input::old('custom_format', (($field->format!='') && (stripos($field->format,'regex')===0)) ? $field->format : ''), array('class' => 'form-control', 'id' => 'custom_format', 'placeholder'=>'regex:/^[0-9]{15}$/')) }}
|
||||||
<p class="help-block">{!! trans('admin/custom_fields/general.field_custom_format_help') !!}</p>
|
<p class="help-block">{!! trans('admin/custom_fields/general.field_custom_format_help') !!}</p>
|
||||||
|
|
||||||
{!! $errors->first('custom_format', '<span class="alert-msg"><i class="fa fa-times"></i> :message</span>') !!}
|
{!! $errors->first('custom_format', '<span class="alert-msg"><i class="fa fa-times"></i> :message</span>') !!}
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -143,6 +144,7 @@
|
||||||
// If the custom_regex is ever NOT the last element in the format
|
// If the custom_regex is ever NOT the last element in the format
|
||||||
// listbox, we will need to refactor this.
|
// listbox, we will need to refactor this.
|
||||||
if ($('#custom_format').val()!='') {
|
if ($('#custom_format').val()!='') {
|
||||||
|
// console.log('value is ' + $('#custom_format').val());
|
||||||
$('.format').prop('selectedIndex', $('.format')[0].options.length - 1);
|
$('.format').prop('selectedIndex', $('.format')[0].options.length - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue