abizvn-cms 0.1.2 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/models/abizvn/cms/article.rb +1 -1
- data/app/models/abizvn/cms/category.rb +4 -2
- data/app/serializers/abizvn/cms/category_lite_serializer.rb +1 -9
- data/app/services/abizvn/cms/cms_service.rb +49 -0
- data/db/migrate/20250426050330_update_category_remove_general.rb +22 -0
- data/db/migrate/20250427041233_add_order_to_category.rb +5 -0
- data/lib/abizvn/cms/version.rb +5 -5
- data/lib/abizvn/cms.rb +12 -8
- metadata +5 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6c689fc2686c612d20f01b31437aaf1ad3abc02a7d0f8bfc2b204014e00a2d51
|
4
|
+
data.tar.gz: fd1d98a454e3f95672905fd81912bf0518468b0295577927a4cc43bd58baae6a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5390b9b6533ca97f07686e6d7fc4ff53db816139f18ed7a55d4de26f5bedd3ad2a6d2472d15612f838a28de3bd9502c2ed261a4fcf89a06dc551cfaef1818e13
|
7
|
+
data.tar.gz: 40d48576996fc044850a44457e64aa558e1761e0a4f1e22085e2f495d91bd8ee27aa66c0c3ca7b6329eecf657e97c200c1288d5950be98a65b1ef0e61bb9a198
|
@@ -9,7 +9,7 @@ module Abizvn
|
|
9
9
|
scope :ordered, -> { order(updated_at: :desc) }
|
10
10
|
|
11
11
|
belongs_to :status, class_name: 'Abizvn::General::GeneralSetting'
|
12
|
-
belongs_to :category, class_name:
|
12
|
+
belongs_to :category, class_name: Abizvn::Cms.category_class, counter_cache: true
|
13
13
|
|
14
14
|
has_many :comments, as: :commentable, dependent: :destroy
|
15
15
|
|
@@ -5,9 +5,11 @@ module Abizvn
|
|
5
5
|
|
6
6
|
self.table_name = 'cms_categories'
|
7
7
|
|
8
|
-
belongs_to :
|
9
|
-
|
8
|
+
belongs_to :status, class_name: 'Abizvn::General::GeneralSetting'
|
9
|
+
|
10
10
|
has_many :articles, foreign_key: :category_id
|
11
|
+
|
12
|
+
validates :status, :code, :name, presence: true
|
11
13
|
end
|
12
14
|
end
|
13
15
|
end
|
@@ -3,15 +3,7 @@ module Abizvn
|
|
3
3
|
class CategoryLiteSerializer
|
4
4
|
include JSONAPI::Serializer
|
5
5
|
|
6
|
-
attributes :id
|
7
|
-
|
8
|
-
attribute :code do |entity|
|
9
|
-
entity.general.code
|
10
|
-
end
|
11
|
-
|
12
|
-
attribute :value do |entity|
|
13
|
-
entity.general.value
|
14
|
-
end
|
6
|
+
attributes :id, :code, :name, :updated_at
|
15
7
|
end
|
16
8
|
end
|
17
9
|
end
|
@@ -0,0 +1,49 @@
|
|
1
|
+
module Abizvn
|
2
|
+
module Cms
|
3
|
+
class CmsService
|
4
|
+
STATUS_PUBLIC = 'public'.freeze
|
5
|
+
|
6
|
+
STATUS_TABLE_NAME = GeneralSetting.table_name
|
7
|
+
ARTICLE_TABLE_NAME = Article.table_name
|
8
|
+
|
9
|
+
def self.get_articles_by_status(status_codes, filter_options)
|
10
|
+
category_id = filter_options[:category_id]
|
11
|
+
article_id = filter_options[:article_id]
|
12
|
+
|
13
|
+
query = Article.joins(:status).where("#{STATUS_TABLE_NAME}.code": status_codes).ordered
|
14
|
+
|
15
|
+
if category_id.present?
|
16
|
+
query = query.where(category_id: category_id)
|
17
|
+
elsif article_id.present?
|
18
|
+
query = query.where(category_id: Article.select(:category_id).where(slug: article_id))
|
19
|
+
end
|
20
|
+
|
21
|
+
return query
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.find_article(id, status_code)
|
25
|
+
Article.joins(:status, :category).includes(:category).where("#{STATUS_TABLE_NAME}.code": status_code).friendly.find(id)
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.get_categories_with_latest_articles(category_tag = nil, nb_articles = 5)
|
29
|
+
subquery = Article.joins(:status, :category)
|
30
|
+
.select("#{ARTICLE_TABLE_NAME}.*, ROW_NUMBER() OVER (PARTITION BY category_id ORDER BY #{ARTICLE_TABLE_NAME}.updated_at DESC) as row_num")
|
31
|
+
.where("#{STATUS_TABLE_NAME}.code": STATUS_PUBLIC)
|
32
|
+
.to_sql
|
33
|
+
|
34
|
+
articles = Article.select('*')
|
35
|
+
.from("(#{subquery}) as articles_with_row_numbers")
|
36
|
+
.where('row_num <= ?', nb_articles)
|
37
|
+
.includes(:category)
|
38
|
+
|
39
|
+
if category_tag.present?
|
40
|
+
articles = articles.where("#{Category.table_name}.tag": category_tag)
|
41
|
+
end
|
42
|
+
|
43
|
+
categories = articles.map(&:category).uniq.sort { |c| c.order }
|
44
|
+
|
45
|
+
return [categories, articles]
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
class UpdateCategoryRemoveGeneral < ActiveRecord::Migration[7.2]
|
2
|
+
def change
|
3
|
+
change_table :cms_categories do |t|
|
4
|
+
t.string :code
|
5
|
+
t.string :name
|
6
|
+
t.references :status, foreign_key: { to_table: :general_settings }, index: true
|
7
|
+
end
|
8
|
+
|
9
|
+
execute <<-SQL
|
10
|
+
UPDATE cms_categories
|
11
|
+
SET code = gs.code,
|
12
|
+
name = gs.value
|
13
|
+
FROM general_settings gs
|
14
|
+
WHERE cms_categories.general_id = gs.id
|
15
|
+
SQL
|
16
|
+
|
17
|
+
change_column_null :cms_categories, :code, false
|
18
|
+
change_column_null :cms_categories, :name, false
|
19
|
+
|
20
|
+
remove_reference :cms_categories, :general, index: true, foreign_key: { to_table: :general_settings }
|
21
|
+
end
|
22
|
+
end
|
data/lib/abizvn/cms/version.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
module Abizvn
|
2
|
-
module Cms
|
3
|
-
VERSION = "0.1
|
4
|
-
end
|
5
|
-
end
|
1
|
+
module Abizvn
|
2
|
+
module Cms
|
3
|
+
VERSION = "0.2.1"
|
4
|
+
end
|
5
|
+
end
|
data/lib/abizvn/cms.rb
CHANGED
@@ -1,8 +1,12 @@
|
|
1
|
-
require "abizvn/cms/version"
|
2
|
-
require "abizvn/cms/engine"
|
3
|
-
|
4
|
-
module Abizvn
|
5
|
-
module Cms
|
6
|
-
|
7
|
-
|
8
|
-
|
1
|
+
require "abizvn/cms/version"
|
2
|
+
require "abizvn/cms/engine"
|
3
|
+
|
4
|
+
module Abizvn
|
5
|
+
module Cms
|
6
|
+
mattr_accessor :category_class
|
7
|
+
|
8
|
+
def self.category_class
|
9
|
+
@@category_class ||= "Category"
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: abizvn-cms
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1
|
4
|
+
version: 0.2.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Juan
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2025-
|
11
|
+
date: 2025-04-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -173,12 +173,15 @@ files:
|
|
173
173
|
- app/serializers/abizvn/cms/article_serializer.rb
|
174
174
|
- app/serializers/abizvn/cms/category_articles_serializer.rb
|
175
175
|
- app/serializers/abizvn/cms/category_lite_serializer.rb
|
176
|
+
- app/services/abizvn/cms/cms_service.rb
|
176
177
|
- app/views/layouts/abizvn/cms/application.html.erb
|
177
178
|
- config/routes.rb
|
178
179
|
- db/migrate/20250117094449_create_category.rb
|
179
180
|
- db/migrate/20250117094450_create_articles.rb
|
180
181
|
- db/migrate/20250119070204_add_articles_count_to_category.rb
|
181
182
|
- db/migrate/20250301063841_add_slug_to_articles.rb
|
183
|
+
- db/migrate/20250426050330_update_category_remove_general.rb
|
184
|
+
- db/migrate/20250427041233_add_order_to_category.rb
|
182
185
|
- lib/abizvn/cms.rb
|
183
186
|
- lib/abizvn/cms/engine.rb
|
184
187
|
- lib/abizvn/cms/version.rb
|