[增添]添加了datasource的setting数据库以及默认值

This commit is contained in:
makotocc0107
2024-08-27 09:57:44 +08:00
parent d111dfaea4
commit 72eb990970
10955 changed files with 978898 additions and 0 deletions

View File

@@ -0,0 +1,7 @@
<?php
namespace AnourValar\EloquentSerialize\Tests\Models;
class File extends \Illuminate\Database\Eloquent\Model
{
}

View File

@@ -0,0 +1,16 @@
<?php
namespace AnourValar\EloquentSerialize\Tests\Models;
class Post extends \Illuminate\Database\Eloquent\Model
{
public function user()
{
return $this->belongsTo(User::class);
}
public function tag()
{
return $this->morphOne(Tag::class, 'taggable');
}
}

View File

@@ -0,0 +1,11 @@
<?php
namespace AnourValar\EloquentSerialize\Tests\Models;
class Tag extends \Illuminate\Database\Eloquent\Model
{
public function taggable()
{
return $this->morphTo();
}
}

View File

@@ -0,0 +1,76 @@
<?php
namespace AnourValar\EloquentSerialize\Tests\Models;
class User extends \Illuminate\Database\Eloquent\Model
{
use \Illuminate\Database\Eloquent\SoftDeletes;
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function userPhones()
{
return $this->hasMany(UserPhone::class);
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function userPhonesSorted()
{
return $this->hasMany(UserPhone::class)->orderBy('phone', 'ASC');
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function userPhonesPrimary()
{
return $this->hasMany(UserPhone::class)->where('is_primary', '=', true);
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasManyThrough
*/
public function userPhoneNote()
{
return $this->hasManyThrough(UserPhoneNote::class, UserPhone::class);
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasOneThrough
*/
public function userPhoneNoteAlt()
{
return $this->through($this->userPhones())
->has(fn (UserPhone $userPhone) => $userPhone->userPhoneNote());
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function filesAB()
{
return $this->hasMany(File::class, 'user_id')->whereIn('type', ['a', 'b']);
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function filesC()
{
return $this->hasMany(File::class, 'user_id', 'id')->where('type', 'c');
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function filesDE()
{
return $this->hasOne(File::class)
->whereNotIn('type', ['f', 'g'])
->whereIn('type', ['d', 'e'])
->whereNotIn('type', ['a', 'b', 'c']);
}
}

View File

@@ -0,0 +1,44 @@
<?php
namespace AnourValar\EloquentSerialize\Tests\Models;
class UserPhone extends \Illuminate\Database\Eloquent\Model
{
/**
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
*/
public function user()
{
return $this->belongsTo(User::class);
}
/**
* @return \Illuminate\Database\Eloquent\Relations\HasOne
*/
public function userPhoneNote()
{
return $this->hasOne(UserPhoneNote::class);
}
/**
* @param \Illuminate\Database\Eloquent\Builder $query
* @param bool $isPrimary
* @return void
*/
public function scopeMajor(\Illuminate\Database\Eloquent\Builder $query, bool $isPrimary)
{
$query->where('is_primary', '=', $isPrimary);
}
/**
* @param \Illuminate\Database\Eloquent\Builder $query
* @param string $pattern
* @return void
*/
public function scopeSearch(\Illuminate\Database\Eloquent\Builder $query, string $pattern)
{
$query->where(function ($query) use ($pattern) {
$query->where('phone', 'LIKE', "%$pattern%");
});
}
}

View File

@@ -0,0 +1,11 @@
<?php
namespace AnourValar\EloquentSerialize\Tests\Models;
class UserPhoneNote extends \Illuminate\Database\Eloquent\Model
{
public function userPhone()
{
return $this->belongsTo(UserPhone::class);
}
}