107 lines
2.3 KiB
Ruby
107 lines
2.3 KiB
Ruby
require "time_math"
|
|
|
|
module Admin
|
|
module Repos
|
|
class PostRepo < Adamantium::Repo[:posts]
|
|
commands update: :by_pk
|
|
|
|
def tag_post(post_id:, tags:)
|
|
tags.each do |tag_name|
|
|
next if tag_name == ""
|
|
|
|
tag = posts.tags.where(label: tag_name).one ||
|
|
posts
|
|
.tags
|
|
.changeset(:create, {label: tag_name, slug: tag_name.downcase.strip.tr(" ", "-").gsub(/[^\w-]/, "")})
|
|
.commit
|
|
|
|
next if posts
|
|
.post_tags
|
|
.where(
|
|
post_id: post_id,
|
|
tag_id: tag[:id]
|
|
).count > 0
|
|
|
|
posts.post_tags.changeset(:create, {
|
|
post_id: post_id,
|
|
tag_id: tag[:id]
|
|
})
|
|
.commit
|
|
end
|
|
end
|
|
|
|
def auto_tag_post(post_id:, tag_id:)
|
|
return if posts
|
|
.post_tags
|
|
.where(
|
|
post_id: post_id,
|
|
tag_id: tag_id
|
|
).count > 0
|
|
|
|
posts
|
|
.post_tags
|
|
.changeset(:create, {
|
|
post_id: post_id,
|
|
tag_id: tag_id
|
|
})
|
|
.commit
|
|
end
|
|
|
|
def by_title(title_contains:)
|
|
posts
|
|
.where(post_type: "post")
|
|
.published
|
|
.where(Sequel.ilike(:name, "%#{title_contains}%")).to_a
|
|
end
|
|
|
|
def by_content(body_contains:)
|
|
posts
|
|
.where(post_type: "post")
|
|
.published
|
|
.where(Sequel.ilike(:content, "%#{body_contains}%")).to_a
|
|
end
|
|
|
|
def list
|
|
posts
|
|
.where(post_type: ["post", "checkin"])
|
|
.order(Sequel.lit("published_at desc"))
|
|
.to_a
|
|
end
|
|
|
|
def find(id:)
|
|
posts
|
|
.combine(:tags)
|
|
.where(id: id).one!
|
|
end
|
|
|
|
def delete(id:)
|
|
posts.where(id: id).delete
|
|
end
|
|
|
|
def publish(id:)
|
|
posts.where(id: id).update(published_at: Time.now)
|
|
end
|
|
|
|
def archive(id:)
|
|
posts.where(id: id).update(published_at: nil)
|
|
end
|
|
|
|
def created_between(start_date, end_date)
|
|
end_date = TimeMath.month.advance(end_date, +2)
|
|
|
|
posts
|
|
.combine(:trips)
|
|
.published_between(start_date, end_date)
|
|
.to_a
|
|
end
|
|
|
|
def remove_tags(post_id:)
|
|
posts
|
|
.post_tags
|
|
.where(post_id: post_id)
|
|
.delete
|
|
end
|
|
end
|
|
end
|
|
end
|