312 lines
6.1 KiB
Elixir
312 lines
6.1 KiB
Elixir
defmodule ChoreTracker.Chores do
|
|
@moduledoc """
|
|
The Chores context.
|
|
"""
|
|
|
|
import Ecto.Query, warn: false
|
|
alias ChoreTracker.Chores.ChoreLog
|
|
alias ChoreTracker.Repo
|
|
alias ChoreTracker.Chores.Chore
|
|
alias ChoreTracker.Accounts.User
|
|
|
|
@doc """
|
|
Returns the list of chores.
|
|
|
|
## Examples
|
|
|
|
iex> list_chores()
|
|
[%Chore{}, ...]
|
|
|
|
"""
|
|
def list_chores do
|
|
logs = from(log in ChoreLog, limit: 1)
|
|
from(chore in Chore, preload: [logs: ^logs]) |> Repo.all()
|
|
end
|
|
|
|
@doc """
|
|
Gets a single chore.
|
|
|
|
Raises `Ecto.NoResultsError` if the Chore does not exist.
|
|
|
|
## Examples
|
|
|
|
iex> get_chore!(123)
|
|
%Chore{}
|
|
|
|
iex> get_chore!(456)
|
|
** (Ecto.NoResultsError)
|
|
|
|
"""
|
|
def get_chore!(id), do: Repo.get!(Chore, id) |> Repo.preload([{:logs, :user}])
|
|
|
|
@doc """
|
|
Creates a chore.
|
|
|
|
## Examples
|
|
|
|
iex> create_chore(%{field: value})
|
|
{:ok, %Chore{}}
|
|
|
|
iex> create_chore(%{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def create_chore(attrs \\ %{}) do
|
|
%Chore{}
|
|
|> Chore.changeset(attrs)
|
|
|> Repo.insert()
|
|
end
|
|
|
|
@doc """
|
|
Updates a chore.
|
|
|
|
## Examples
|
|
|
|
iex> update_chore(chore, %{field: new_value})
|
|
{:ok, %Chore{}}
|
|
|
|
iex> update_chore(chore, %{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def update_chore(%Chore{} = chore, attrs) do
|
|
chore
|
|
|> Chore.changeset(attrs)
|
|
|> Repo.update()
|
|
end
|
|
|
|
@doc """
|
|
Deletes a chore.
|
|
|
|
## Examples
|
|
|
|
iex> delete_chore(chore)
|
|
{:ok, %Chore{}}
|
|
|
|
iex> delete_chore(chore)
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def delete_chore(%Chore{} = chore) do
|
|
Repo.delete(chore)
|
|
end
|
|
|
|
@doc """
|
|
Returns an `%Ecto.Changeset{}` for tracking chore changes.
|
|
|
|
## Examples
|
|
|
|
iex> change_chore(chore)
|
|
%Ecto.Changeset{data: %Chore{}}
|
|
|
|
"""
|
|
def change_chore(%Chore{} = chore, attrs \\ %{}) do
|
|
Chore.changeset(chore, attrs)
|
|
end
|
|
|
|
alias ChoreTracker.Chores.ChoreLog
|
|
|
|
@doc """
|
|
Returns the list of chore_logs.
|
|
|
|
## Examples
|
|
|
|
iex> list_chore_logs()
|
|
[%ChoreLog{}, ...]
|
|
|
|
"""
|
|
def list_chore_logs do
|
|
Repo.all(ChoreLog)
|
|
end
|
|
|
|
@doc """
|
|
Gets a single chore_log.
|
|
|
|
Raises `Ecto.NoResultsError` if the Chore log does not exist.
|
|
|
|
## Examples
|
|
|
|
iex> get_chore_log!(123)
|
|
%ChoreLog{}
|
|
|
|
iex> get_chore_log!(456)
|
|
** (Ecto.NoResultsError)
|
|
|
|
"""
|
|
def get_chore_log!(id), do: Repo.get!(ChoreLog, id)
|
|
|
|
@doc """
|
|
Creates a chore_log.
|
|
|
|
## Examples
|
|
|
|
iex> create_chore_log(%{field: value})
|
|
{:ok, %ChoreLog{}}
|
|
|
|
iex> create_chore_log(%{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
|
|
def log_chore_execution(%User{} = user, %Chore{} = chore) do
|
|
%ChoreLog{}
|
|
|> ChoreLog.changeset(%{user_id: user.id, chore_id: chore.id})
|
|
|> Repo.insert()
|
|
end
|
|
|
|
@doc """
|
|
Updates a chore_log.
|
|
|
|
## Examples
|
|
|
|
iex> update_chore_log(chore_log, %{field: new_value})
|
|
{:ok, %ChoreLog{}}
|
|
|
|
iex> update_chore_log(chore_log, %{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def update_chore_log(%ChoreLog{} = chore_log, attrs) do
|
|
chore_log
|
|
|> ChoreLog.changeset(attrs)
|
|
|> Repo.update()
|
|
end
|
|
|
|
@doc """
|
|
Deletes a chore_log.
|
|
|
|
## Examples
|
|
|
|
iex> delete_chore_log(chore_log)
|
|
{:ok, %ChoreLog{}}
|
|
|
|
iex> delete_chore_log(chore_log)
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def delete_chore_log(%ChoreLog{} = chore_log) do
|
|
Repo.delete(chore_log)
|
|
end
|
|
|
|
@doc """
|
|
Returns an `%Ecto.Changeset{}` for tracking chore_log changes.
|
|
|
|
## Examples
|
|
|
|
iex> change_chore_log(chore_log)
|
|
%Ecto.Changeset{data: %ChoreLog{}}
|
|
|
|
"""
|
|
def change_chore_log(%ChoreLog{} = chore_log, attrs \\ %{}) do
|
|
ChoreLog.changeset(chore_log, attrs)
|
|
end
|
|
|
|
alias ChoreTracker.Chores.ChoreAssignee
|
|
|
|
@doc """
|
|
Returns the list of chore_assignees.
|
|
|
|
## Examples
|
|
|
|
iex> list_chore_assignees()
|
|
[%ChoreAssignee{}, ...]
|
|
|
|
"""
|
|
def list_chore_assignees do
|
|
Repo.all(ChoreAssignee)
|
|
end
|
|
|
|
@doc """
|
|
Gets a single chore_assignee.
|
|
|
|
Raises `Ecto.NoResultsError` if the Chore assignee does not exist.
|
|
|
|
## Examples
|
|
|
|
iex> get_chore_assignee!(123)
|
|
%ChoreAssignee{}
|
|
|
|
iex> get_chore_assignee!(456)
|
|
** (Ecto.NoResultsError)
|
|
|
|
"""
|
|
def get_chore_assignee!(id), do: Repo.get!(ChoreAssignee, id)
|
|
|
|
@doc """
|
|
Creates a chore_assignee.
|
|
|
|
## Examples
|
|
|
|
iex> create_chore_assignee(%{field: value})
|
|
{:ok, %ChoreAssignee{}}
|
|
|
|
iex> create_chore_assignee(%{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def create_chore_assignee(attrs \\ %{}) do
|
|
%ChoreAssignee{}
|
|
|> ChoreAssignee.changeset(attrs)
|
|
|> Repo.insert()
|
|
end
|
|
|
|
@doc """
|
|
Updates a chore_assignee.
|
|
|
|
## Examples
|
|
|
|
iex> update_chore_assignee(chore_assignee, %{field: new_value})
|
|
{:ok, %ChoreAssignee{}}
|
|
|
|
iex> update_chore_assignee(chore_assignee, %{field: bad_value})
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def update_chore_assignee(%ChoreAssignee{} = chore_assignee, attrs) do
|
|
chore_assignee
|
|
|> ChoreAssignee.changeset(attrs)
|
|
|> Repo.update()
|
|
end
|
|
|
|
@doc """
|
|
Deletes a chore_assignee.
|
|
|
|
## Examples
|
|
|
|
iex> delete_chore_assignee(chore_assignee)
|
|
{:ok, %ChoreAssignee{}}
|
|
|
|
iex> delete_chore_assignee(chore_assignee)
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
"""
|
|
def delete_chore_assignee(%ChoreAssignee{} = chore_assignee) do
|
|
Repo.delete(chore_assignee)
|
|
end
|
|
|
|
@doc """
|
|
Returns an `%Ecto.Changeset{}` for tracking chore_assignee changes.
|
|
|
|
## Examples
|
|
|
|
iex> change_chore_assignee(chore_assignee)
|
|
%Ecto.Changeset{data: %ChoreAssignee{}}
|
|
|
|
"""
|
|
def change_chore_assignee(%ChoreAssignee{} = chore_assignee, attrs \\ %{}) do
|
|
ChoreAssignee.changeset(chore_assignee, attrs)
|
|
end
|
|
|
|
def display_chore_frequency(%Chore{} = chore) do
|
|
unit = Atom.to_string(chore.period_unit) <> if chore.period > 1, do: "s", else: ""
|
|
"#{chore.period} #{unit}"
|
|
end
|
|
|
|
def next_chore_execution_date(%Chore{logs: [log | _]} = chore) do
|
|
Date.shift(log.inserted_at, [{chore.period_unit, chore.period}])
|
|
end
|
|
|
|
def next_chore_execution_date(%Chore{logs: []} = chore) do
|
|
chore.starts_at
|
|
end
|
|
end
|