PhoenixKit.Modules.Entities.EntityData (phoenix_kit v1.7.42)

Copy Markdown View Source

Entity data records for PhoenixKit entities system.

This module manages actual data records that follow entity blueprints. Each record is associated with an entity type and stores its field values in a JSONB column for flexibility.

Schema Fields

  • entity_id: Foreign key to the entity blueprint
  • title: Display title/name for the record
  • slug: URL-friendly identifier (optional)
  • status: Record status ("draft", "published", "archived")
  • data: JSONB map of all field values based on entity definition
  • metadata: JSONB map for additional information (tags, categories, etc.)
  • created_by: User ID who created the record
  • date_created: When the record was created
  • date_updated: When the record was last modified

Core Functions

Data Management

Query Helpers

Usage Examples

# Create a brand data record
{:ok, data} = PhoenixKit.Modules.Entities.EntityData.create(%{
  entity_id: brand_entity.id,
  title: "Acme Corporation",
  slug: "acme-corporation",
  status: "published",
  created_by: user.id,
  data: %{
    "name" => "Acme Corporation",
    "tagline" => "Quality products since 1950",
    "description" => "<p>Leading manufacturer of innovative products</p>",
    "industry" => "Manufacturing",
    "founded_date" => "1950-03-15",
    "featured" => true
  },
  metadata: %{
    "tags" => ["manufacturing", "industrial"],
    "contact_email" => "info@acme.com"
  }
})

# Get all records for an entity
records = PhoenixKit.Modules.Entities.EntityData.list_by_entity(brand_entity.id)

# Search by title
results = PhoenixKit.Modules.Entities.EntityData.search_by_title("Acme", brand_entity.id)

Summary

Functions

Bulk deletes multiple records by UUIDs.

Bulk updates the category of multiple records by UUIDs.

Bulk updates the status of multiple records by UUIDs.

Returns an %Ecto.Changeset{} for tracking entity data changes.

Creates a changeset for entity data creation and updates.

Counts the total number of records for an entity.

Creates an entity data record.

Deletes an entity data record.

Alias for delete/1 for consistency with LiveView naming.

Extracts unique categories from a list of entity data records.

Gets records filtered by status across all entities.

Gets a single entity data record by ID or UUID.

Gets a single entity data record by ID or UUID.

Gets a single entity data record by entity and slug.

Alias for get!/1 for consistency with LiveView naming.

Gets statistical data about entity data records.

Returns all entity data records ordered by creation date.

Alias for list_all/0 for consistency with LiveView naming.

Returns all entity data records for a specific entity.

Returns entity data records filtered by entity and status.

Alias for list_by_entity/1 for consistency with LiveView naming.

Alias for filter_by_status/1 for consistency with LiveView naming.

Gets all published records for a specific entity.

Searches entity data records by title.

Alias for search_by_title/1 for consistency with LiveView naming.

Updates an entity data record.

Alias for update/2 for consistency with LiveView naming.

Functions

bulk_delete(uuids)

Bulk deletes multiple records by UUIDs.

Returns a tuple with the count of deleted records and nil.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.bulk_delete(["uuid1", "uuid2"])
{2, nil}

bulk_update_category(uuids, category)

Bulk updates the category of multiple records by UUIDs.

Uses PostgreSQL jsonb_set to update the category field in the JSONB data column in a single query.

Returns a tuple with the count of updated records and nil.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.bulk_update_category(["uuid1", "uuid2"], "New Category")
{2, nil}

bulk_update_status(uuids, status)

Bulk updates the status of multiple records by UUIDs.

Returns a tuple with the count of updated records and nil.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.bulk_update_status(["uuid1", "uuid2"], "archived")
{2, nil}

change(entity_data, attrs \\ %{})

Returns an %Ecto.Changeset{} for tracking entity data changes.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.change(record)
%Ecto.Changeset{data: %PhoenixKit.Modules.Entities.EntityData{}}

changeset(entity_data, attrs)

Creates a changeset for entity data creation and updates.

Validates that entity exists, title is present, and data validates against entity definition. Automatically sets date_created on new records.

count_by_entity(entity_uuid)

Counts the total number of records for an entity.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.count_by_entity(1)
42

create(attrs \\ %{})

Creates an entity data record.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.create(%{entity_id: 1, title: "Test"})
{:ok, %PhoenixKit.Modules.Entities.EntityData{}}

iex> PhoenixKit.Modules.Entities.EntityData.create(%{title: ""})
{:error, %Ecto.Changeset{}}

Note: created_by is auto-filled with the first admin or user ID if not provided, but only if at least one user exists in the system. If no users exist, the changeset will fail with a validation error on created_by.

delete(entity_data)

Deletes an entity data record.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.delete(record)
{:ok, %PhoenixKit.Modules.Entities.EntityData{}}

iex> PhoenixKit.Modules.Entities.EntityData.delete(record)
{:error, %Ecto.Changeset{}}

delete_data(entity_data)

Alias for delete/1 for consistency with LiveView naming.

extract_unique_categories(entity_data_records)

Extracts unique categories from a list of entity data records.

Returns a sorted list of unique category values, excluding nil and empty strings.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.extract_unique_categories(records)
["Category A", "Category B", "Category C"]

filter_by_status(status)

Gets records filtered by status across all entities.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.filter_by_status("draft")
[%PhoenixKit.Modules.Entities.EntityData{status: "draft"}, ...]

get(id)

Gets a single entity data record by ID or UUID.

Accepts:

  • Integer ID (primary key)
  • UUID string
  • String that parses to integer

Returns the record if found, nil otherwise.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.get(123)
%PhoenixKit.Modules.Entities.EntityData{}

iex> PhoenixKit.Modules.Entities.EntityData.get("550e8400-e29b-41d4-a716-446655440000")
%PhoenixKit.Modules.Entities.EntityData{}

iex> PhoenixKit.Modules.Entities.EntityData.get(456)
nil

get!(id)

Gets a single entity data record by ID or UUID.

Accepts:

  • Integer ID (primary key)
  • UUID string
  • String that parses to integer

Raises Ecto.NoResultsError if the record does not exist.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.get!(123)
%PhoenixKit.Modules.Entities.EntityData{}

iex> PhoenixKit.Modules.Entities.EntityData.get!("550e8400-e29b-41d4-a716-446655440000")
%PhoenixKit.Modules.Entities.EntityData{}

iex> PhoenixKit.Modules.Entities.EntityData.get!(456)
** (Ecto.NoResultsError)

get_by_slug(entity_uuid, slug)

Gets a single entity data record by entity and slug.

Returns the record if found, nil otherwise.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.get_by_slug(1, "acme-corporation")
%PhoenixKit.Modules.Entities.EntityData{}

iex> PhoenixKit.Modules.Entities.EntityData.get_by_slug(1, "invalid")
nil

get_data!(id)

Alias for get!/1 for consistency with LiveView naming.

get_data_stats(entity_id \\ nil)

Gets statistical data about entity data records.

Returns statistics about total records, published, draft, and archived counts. Optionally filters by entity_id if provided.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.get_data_stats()
%{
  total_records: 150,
  published_records: 120,
  draft_records: 25,
  archived_records: 5
}

iex> PhoenixKit.Modules.Entities.EntityData.get_data_stats(1)
%{
  total_records: 15,
  published_records: 12,
  draft_records: 2,
  archived_records: 1
}

list_all()

Returns all entity data records ordered by creation date.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.list_all()
[%PhoenixKit.Modules.Entities.EntityData{}, ...]

list_all_data()

Alias for list_all/0 for consistency with LiveView naming.

list_by_entity(entity_uuid)

Returns all entity data records for a specific entity.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.list_by_entity(1)
[%PhoenixKit.Modules.Entities.EntityData{entity_id: 1}, ...]

list_by_entity_and_status(entity_uuid, status)

Returns entity data records filtered by entity and status.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.list_by_entity_and_status(1, "published")
[%PhoenixKit.Modules.Entities.EntityData{entity_id: 1, status: "published"}, ...]

list_data_by_entity(entity_id)

Alias for list_by_entity/1 for consistency with LiveView naming.

list_data_by_status(status)

Alias for filter_by_status/1 for consistency with LiveView naming.

published_records(entity_uuid)

Gets all published records for a specific entity.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.published_records(1)
[%PhoenixKit.Modules.Entities.EntityData{status: "published"}, ...]

search_by_title(search_term, entity_id \\ nil)

Searches entity data records by title.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.search_by_title("Acme", 1)
[%PhoenixKit.Modules.Entities.EntityData{}, ...]

search_data(search_term)

Alias for search_by_title/1 for consistency with LiveView naming.

update(entity_data, attrs)

Updates an entity data record.

Examples

iex> PhoenixKit.Modules.Entities.EntityData.update(record, %{title: "Updated"})
{:ok, %PhoenixKit.Modules.Entities.EntityData{}}

iex> PhoenixKit.Modules.Entities.EntityData.update(record, %{title: ""})
{:error, %Ecto.Changeset{}}

update_data(entity_data, attrs)

Alias for update/2 for consistency with LiveView naming.