mirror of
https://github.com/ash-project/ash_postgres.git
synced 2024-09-21 14:03:15 +12:00
51 lines
1.2 KiB
Elixir
51 lines
1.2 KiB
Elixir
|
defmodule AshPostgres.Test.ComplexCalculations.Skill do
|
||
|
@moduledoc false
|
||
|
use Ash.Resource, data_layer: AshPostgres.DataLayer
|
||
|
|
||
|
actions do
|
||
|
defaults([:create, :read, :update, :destroy])
|
||
|
end
|
||
|
|
||
|
aggregates do
|
||
|
first :latest_documentation_status, [:documentations], :status do
|
||
|
sort(timestamp: :desc)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
attributes do
|
||
|
uuid_primary_key(:id)
|
||
|
attribute(:removed, :boolean, default: false, allow_nil?: false)
|
||
|
end
|
||
|
|
||
|
calculations do
|
||
|
calculate :status, :atom do
|
||
|
calculation(
|
||
|
expr(
|
||
|
if is_nil(latest_documentation_status) do
|
||
|
:pending
|
||
|
else
|
||
|
latest_documentation_status
|
||
|
end
|
||
|
)
|
||
|
)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
postgres do
|
||
|
table "complex_calculations_skills"
|
||
|
repo(AshPostgres.TestRepo)
|
||
|
end
|
||
|
|
||
|
relationships do
|
||
|
belongs_to(:certification, AshPostgres.Test.ComplexCalculations.Certification)
|
||
|
|
||
|
has_many :documentations, AshPostgres.Test.ComplexCalculations.Documentation do
|
||
|
sort(timestamp: :desc, inserted_at: :desc)
|
||
|
end
|
||
|
|
||
|
has_one :latest_documentation, AshPostgres.Test.ComplexCalculations.Documentation do
|
||
|
sort(timestamp: :desc, inserted_at: :desc)
|
||
|
end
|
||
|
end
|
||
|
end
|