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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 5ba582710db4f69bcd4763391b110d3fe1475dc186d6af48bc0a264b3670808e
4
- data.tar.gz: de72b53fc5d6b651d1f00b4494a58652db9cfbe6c3f163ebf3e8be7079a07709
3
+ metadata.gz: 6c689fc2686c612d20f01b31437aaf1ad3abc02a7d0f8bfc2b204014e00a2d51
4
+ data.tar.gz: fd1d98a454e3f95672905fd81912bf0518468b0295577927a4cc43bd58baae6a
5
5
  SHA512:
6
- metadata.gz: 8c366eb41c5eed5dad90ce1045a0bfca578e374b3cc0800f1c2e555d0b525e808aeaf1bebf72bad111a148cbea8604a1763546c2092c196a212e0b4ecec9b275
7
- data.tar.gz: 2b4c819554f7420a9f45f35a34a71884fa020078c98a8268e355e0ab8e37a0dc54fc1f8fd1f7680b0eff00ebba5251620014f0ed4b7f001b2681bd68cfe004dd
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: 'Category', counter_cache: true
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 :general, class_name: 'Abizvn::General::GeneralSetting'
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
@@ -0,0 +1,5 @@
1
+ class AddOrderToCategory < ActiveRecord::Migration[7.2]
2
+ def change
3
+ add_column :cms_categories, :order, :integer, default: 0, null: false
4
+ end
5
+ end
@@ -1,5 +1,5 @@
1
- module Abizvn
2
- module Cms
3
- VERSION = "0.1.2"
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
- # Your code goes here...
7
- end
8
- end
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.2
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-03-22 00:00:00.000000000 Z
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