2021-03-11 17:16:11 -05:00
|
|
|
defmodule Shift73k.Shifts do
|
|
|
|
@moduledoc """
|
|
|
|
The Shifts context.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import Ecto.Query, warn: false
|
|
|
|
alias Shift73k.Repo
|
|
|
|
|
|
|
|
alias Shift73k.Shifts.Shift
|
|
|
|
|
|
|
|
@doc """
|
|
|
|
Returns the list of shifts.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
iex> list_shifts()
|
|
|
|
[%Shift{}, ...]
|
|
|
|
|
|
|
|
"""
|
|
|
|
def list_shifts do
|
|
|
|
Repo.all(Shift)
|
|
|
|
end
|
|
|
|
|
2021-03-20 12:45:50 -04:00
|
|
|
defp query_shifts_by_user(user_id) do
|
2021-03-19 16:38:52 -04:00
|
|
|
from(s in Shift)
|
2021-03-20 12:45:50 -04:00
|
|
|
|> where([s], s.user_id == ^user_id)
|
|
|
|
end
|
|
|
|
|
2021-03-21 10:47:53 -04:00
|
|
|
def list_shifts_by_user(user_id) do
|
|
|
|
user_id
|
|
|
|
|> query_shifts_by_user()
|
|
|
|
|> Repo.all()
|
|
|
|
end
|
|
|
|
|
2021-03-20 12:45:50 -04:00
|
|
|
def list_shifts_by_user_in_date_range(user_id, %Date.Range{} = date_range) do
|
2021-03-21 10:47:53 -04:00
|
|
|
user_id
|
|
|
|
|> query_shifts_by_user()
|
2021-03-20 12:45:50 -04:00
|
|
|
|> where([s], s.date >= ^date_range.first)
|
|
|
|
|> where([s], s.date <= ^date_range.last)
|
2021-03-19 16:38:52 -04:00
|
|
|
|> order_by([s], [s.date, s.time_start])
|
|
|
|
|> Repo.all()
|
|
|
|
end
|
|
|
|
|
2021-03-20 12:45:50 -04:00
|
|
|
defp query_shifts_by_user_from_list_of_dates(user_id, date_list) do
|
2021-03-21 10:47:53 -04:00
|
|
|
user_id
|
|
|
|
|> query_shifts_by_user()
|
2021-03-20 12:45:50 -04:00
|
|
|
|> where([s], s.date in ^date_list)
|
2021-03-19 16:38:52 -04:00
|
|
|
end
|
|
|
|
|
2021-03-20 12:45:50 -04:00
|
|
|
def list_shifts_by_user_from_list_of_dates(user_id, date_list) do
|
2021-03-21 10:47:53 -04:00
|
|
|
user_id
|
|
|
|
|> query_shifts_by_user_from_list_of_dates(date_list)
|
2021-03-19 16:38:52 -04:00
|
|
|
|> Repo.all()
|
2021-03-16 11:00:33 -04:00
|
|
|
end
|
|
|
|
|
2021-03-11 17:16:11 -05:00
|
|
|
@doc """
|
|
|
|
Gets a single shift.
|
|
|
|
|
|
|
|
Raises `Ecto.NoResultsError` if the Shift does not exist.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
iex> get_shift!(123)
|
|
|
|
%Shift{}
|
|
|
|
|
|
|
|
iex> get_shift!(456)
|
|
|
|
** (Ecto.NoResultsError)
|
|
|
|
|
|
|
|
"""
|
|
|
|
def get_shift!(id), do: Repo.get!(Shift, id)
|
|
|
|
|
|
|
|
@doc """
|
|
|
|
Creates a shift.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
iex> create_shift(%{field: value})
|
|
|
|
{:ok, %Shift{}}
|
|
|
|
|
|
|
|
iex> create_shift(%{field: bad_value})
|
|
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
|
|
|
|
"""
|
|
|
|
def create_shift(attrs \\ %{}) do
|
|
|
|
%Shift{}
|
|
|
|
|> Shift.changeset(attrs)
|
|
|
|
|> Repo.insert()
|
|
|
|
end
|
|
|
|
|
|
|
|
@doc """
|
|
|
|
Updates a shift.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
iex> update_shift(shift, %{field: new_value})
|
|
|
|
{:ok, %Shift{}}
|
|
|
|
|
|
|
|
iex> update_shift(shift, %{field: bad_value})
|
|
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
|
|
|
|
"""
|
|
|
|
def update_shift(%Shift{} = shift, attrs) do
|
|
|
|
shift
|
|
|
|
|> Shift.changeset(attrs)
|
|
|
|
|> Repo.update()
|
|
|
|
end
|
|
|
|
|
|
|
|
@doc """
|
|
|
|
Deletes a shift.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
iex> delete_shift(shift)
|
|
|
|
{:ok, %Shift{}}
|
|
|
|
|
|
|
|
iex> delete_shift(shift)
|
|
|
|
{:error, %Ecto.Changeset{}}
|
|
|
|
|
|
|
|
"""
|
|
|
|
def delete_shift(%Shift{} = shift) do
|
|
|
|
Repo.delete(shift)
|
|
|
|
end
|
|
|
|
|
2021-03-20 12:45:50 -04:00
|
|
|
def delete_shifts_by_user_from_list_of_dates(user_id, date_list) do
|
|
|
|
query_shifts_by_user_from_list_of_dates(user_id, date_list)
|
2021-03-19 16:38:52 -04:00
|
|
|
|> Repo.delete_all()
|
|
|
|
end
|
|
|
|
|
2021-03-11 17:16:11 -05:00
|
|
|
@doc """
|
|
|
|
Returns an `%Ecto.Changeset{}` for tracking shift changes.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
iex> change_shift(shift)
|
|
|
|
%Ecto.Changeset{data: %Shift{}}
|
|
|
|
|
|
|
|
"""
|
|
|
|
def change_shift(%Shift{} = shift, attrs \\ %{}) do
|
|
|
|
Shift.changeset(shift, attrs)
|
|
|
|
end
|
|
|
|
end
|