dcidev_active_record 0.0.9 → 0.0.12
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/lib/dcidev_active_record.rb +104 -105
- data/lib/nested_attribute_helper.rb +14 -0
- metadata +2 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 81d43d6c23726bfcc5dd25fb8d4cfe17e30ba7f7a11a2c12f7999926e7e7bcae
|
4
|
+
data.tar.gz: b66a24c0c256baf7eb1912e19d574c133e3b0b009340db9d90d59e95b7615d52
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 971004a905d4f940e0ea2649ec22262410577570ca051d59d2b72f3a11f5df06471ae97e6953d355609dabfc7789819d0ca24a011a9a8b72d71d3417bdc46d65
|
7
|
+
data.tar.gz: 450e364d5d0cbc5aa5ed671097cf323ef7cda6d5a518a0debfd05a3309e1500bd24ec807745d1b0c04f7b1713d904ab2e26743293d75d9d9185d7b2cfe0e78d3
|
data/lib/dcidev_active_record.rb
CHANGED
@@ -2,122 +2,121 @@ require 'active_support/concern'
|
|
2
2
|
require 'active_record'
|
3
3
|
|
4
4
|
module DcidevActiveRecord
|
5
|
-
|
6
|
-
|
7
|
-
included do
|
8
|
-
scope :between_date, -> (column, start_date, end_date) {
|
9
|
-
where("#{eval("self.#{ENV['DB']}_date_builder('#{self.table_name}.#{column}')")} BETWEEN '#{start_date}' AND '#{end_date}'")
|
10
|
-
}
|
11
|
-
|
12
|
-
scope :before_or_equal_to_date, -> (column, date) {
|
13
|
-
where("#{eval("self.#{ENV['DB']}_date_builder('#{self.table_name}.#{column}')")} <= '#{date}'")
|
14
|
-
}
|
5
|
+
extend ActiveSupport::Concern
|
15
6
|
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
eval("self.#{c} = params[:#{c.to_sym}]") if params.key?(c.to_sym)
|
46
|
-
eval("self.#{c} = params['#{c}']") if params.key?(c)
|
47
|
-
else
|
48
|
-
eval("self.#{c} = params[:#{c.to_sym}]") if params.key?(c.to_sym) && params[c.to_sym] != nil
|
49
|
-
eval("self.#{c} = params['#{c}']") if params.key?(c) && params[c] != nil
|
50
|
-
end
|
51
|
-
rescue IOError
|
52
|
-
raise "Tidak dapat menyimpan file#{c}"
|
53
|
-
end
|
7
|
+
included do
|
8
|
+
scope :between_date, -> (column, start_date, end_date) {
|
9
|
+
where("#{eval("self.#{ENV['DB']}_date_builder('#{self.table_name}.#{column}')")} BETWEEN '#{start_date}' AND '#{end_date}'")
|
10
|
+
}
|
11
|
+
|
12
|
+
scope :before_or_equal_to_date, -> (column, date) {
|
13
|
+
where("#{eval("self.#{ENV['DB']}_date_builder('#{self.table_name}.#{column}')")} <= '#{date}'")
|
14
|
+
}
|
15
|
+
|
16
|
+
scope :after_or_equal_to_date, -> (column, date) {
|
17
|
+
where("#{eval("self.#{ENV['DB']}_date_builder('#{self.table_name}.#{column}')")} >= '#{date}'")
|
18
|
+
}
|
19
|
+
scope :at_time, -> (column, time) {
|
20
|
+
where("#{eval("self.#{ENV['DB']}_time_builder('#{self.table_name}.#{column}')")} #{self.db_like_string(ENV['DB'])} '%#{time}%'")
|
21
|
+
}
|
22
|
+
scope :mysql_json_contains, ->(column, key, value) { "JSON_EXTRACT(#{column}, '$.\"#{key}\"') LIKE \"%#{value}%\"" }
|
23
|
+
end
|
24
|
+
|
25
|
+
def replace_child_from_array(new_child = [], column_name: "", child_name: "")
|
26
|
+
new_child = new_child.to_a
|
27
|
+
formatted = []
|
28
|
+
existing_child = eval("self.#{child_name}")
|
29
|
+
existing_child_values = existing_child.pluck(column_name.to_sym)
|
30
|
+
delete_child = existing_child_values - new_child
|
31
|
+
(existing_child_values + new_child).uniq.each do |lc|
|
32
|
+
attr = { column_name => lc, "_destroy" => delete_child.include?(lc) }
|
33
|
+
id = existing_child.detect { |ec| eval("ec.#{column_name} == #{lc.is_a?(String) ? "'#{lc}'" : lc}") }
|
34
|
+
attr["id"] = id.id if id.present?
|
35
|
+
formatted << attr
|
54
36
|
end
|
55
|
-
|
56
|
-
|
37
|
+
formatted
|
38
|
+
end
|
39
|
+
|
40
|
+
def update_by_params(params, set_nil = true)
|
41
|
+
ActiveRecord::Base.transaction do
|
42
|
+
self.class.column_names.each do |c|
|
43
|
+
begin
|
44
|
+
if set_nil
|
45
|
+
eval("self.#{c} = params[:#{c.to_sym}]") if params.key?(c.to_sym)
|
46
|
+
eval("self.#{c} = params['#{c}']") if params.key?(c)
|
47
|
+
else
|
48
|
+
eval("self.#{c} = params[:#{c.to_sym}]") if params.key?(c.to_sym) && params[c.to_sym] != nil
|
49
|
+
eval("self.#{c} = params['#{c}']") if params.key?(c) && params[c] != nil
|
50
|
+
end
|
51
|
+
rescue IOError
|
52
|
+
raise "Tidak dapat menyimpan file#{c}"
|
53
|
+
end
|
54
|
+
end
|
55
|
+
params.select { |k, _| !k.is_a?(Symbol) && k.include?("_attributes") }.each do |k, _|
|
56
|
+
eval("self.#{k} = params[:#{k.to_sym}]")
|
57
|
+
end
|
58
|
+
self.save
|
57
59
|
end
|
58
|
-
self.save
|
59
|
-
end
|
60
60
|
end
|
61
|
-
|
62
|
-
|
61
|
+
|
63
62
|
def set_order
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
end
|
72
|
-
|
73
|
-
def reorder
|
74
|
-
return unless self.class.column_names.include?("view_order")
|
75
|
-
return unless self.class.where(view_order: self.view_order).where.not(id: self.id).present?
|
76
|
-
self.class.order(view_order: :asc, updated_at: :desc).each.with_index(1) do |f, i|
|
77
|
-
f.update(view_order: i)
|
78
|
-
end
|
63
|
+
return unless self.class.column_names.include?("view_order")
|
64
|
+
if self.view_order.present?
|
65
|
+
self.reorder
|
66
|
+
else
|
67
|
+
self.view_order = self.class.where.not(id: self.id).count + 1
|
68
|
+
self.save
|
69
|
+
end
|
79
70
|
end
|
80
|
-
|
81
|
-
class_methods do
|
82
71
|
|
83
|
-
def
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
eval("model.#{c} = params['#{c}']") if params.key?(c)
|
89
|
-
|
90
|
-
rescue IOError
|
91
|
-
raise "Tidak dapat menyimpan file #{c}"
|
72
|
+
def reorder
|
73
|
+
return unless self.class.column_names.include?("view_order")
|
74
|
+
return unless self.class.where(view_order: self.view_order).where.not(id: self.id).present?
|
75
|
+
self.class.order(view_order: :asc, updated_at: :desc).each.with_index(1) do |f, i|
|
76
|
+
f.update(view_order: i)
|
92
77
|
end
|
93
|
-
end
|
94
|
-
params.select{|k, _| !k.is_a?(Symbol) && k.include?("_attributes")}.each do |k, _|
|
95
|
-
eval("model.#{k} = params[:#{k.to_sym}]")
|
96
|
-
end
|
97
|
-
model
|
98
|
-
end
|
99
|
-
|
100
|
-
def mysql_date_builder(field)
|
101
|
-
"DATE(CONVERT_TZ(#{field}, '+00:00', '#{Time.now.in_time_zone(Time.zone.name.to_s).formatted_offset}'))"
|
102
|
-
end
|
103
|
-
|
104
|
-
def mysql_time_builder(field)
|
105
|
-
"TIME(CONVERT_TZ(#{field}, '+00:00', '#{Time.now.in_time_zone(Time.zone.name.to_s).formatted_offset}'))"
|
106
|
-
end
|
107
|
-
|
108
|
-
def pgsql_date_builder(field)
|
109
|
-
"DATE(#{field}::TIMESTAMPTZ AT TIME ZONE '#{Time.zone.now.formatted_offset}'::INTERVAL)"
|
110
|
-
end
|
111
|
-
|
112
|
-
def pgsql_time_builder(field)
|
113
|
-
"#{field}::TIMESTAMPTZ AT TIME ZONE '#{Time.zone.now.formatted_offset}'"
|
114
78
|
end
|
115
79
|
|
116
|
-
|
117
|
-
|
118
|
-
|
80
|
+
class_methods do
|
81
|
+
|
82
|
+
def new_from_params(params)
|
83
|
+
model = self.new
|
84
|
+
self.column_names.each do |c|
|
85
|
+
begin
|
86
|
+
eval("model.#{c} = params[:#{c.to_sym}]") if params.key?(c.to_sym)
|
87
|
+
eval("model.#{c} = params['#{c}']") if params.key?(c)
|
88
|
+
|
89
|
+
rescue IOError
|
90
|
+
raise "Tidak dapat menyimpan file #{c}"
|
91
|
+
end
|
92
|
+
end
|
93
|
+
params.select { |k, _| !k.is_a?(Symbol) && k.include?("_attributes") }.each do |k, _|
|
94
|
+
eval("model.#{k} = params[:#{k.to_sym}]")
|
95
|
+
end
|
96
|
+
model
|
97
|
+
end
|
98
|
+
|
99
|
+
def mysql_date_builder(field)
|
100
|
+
"DATE(CONVERT_TZ(#{field}, '+00:00', '#{Time.now.in_time_zone(Time.zone.name.to_s).formatted_offset}'))"
|
101
|
+
end
|
102
|
+
|
103
|
+
def mysql_time_builder(field)
|
104
|
+
"TIME(CONVERT_TZ(#{field}, '+00:00', '#{Time.now.in_time_zone(Time.zone.name.to_s).formatted_offset}'))"
|
105
|
+
end
|
106
|
+
|
107
|
+
def pgsql_date_builder(field)
|
108
|
+
"DATE(#{field}::TIMESTAMPTZ AT TIME ZONE '#{Time.zone.now.formatted_offset}'::INTERVAL)"
|
109
|
+
end
|
110
|
+
|
111
|
+
def pgsql_time_builder(field)
|
112
|
+
"#{field}::TIMESTAMPTZ AT TIME ZONE '#{Time.zone.now.formatted_offset}'"
|
113
|
+
end
|
114
|
+
|
115
|
+
def db_like_string(db)
|
116
|
+
return 'ILIKE' if db == 'pgsql'
|
117
|
+
return 'LIKE' if db == 'mysql'
|
118
|
+
end
|
119
119
|
end
|
120
|
-
end
|
121
120
|
end
|
122
121
|
|
123
122
|
ActiveRecord::Base.send(:include, DcidevActiveRecord)
|
@@ -0,0 +1,14 @@
|
|
1
|
+
module NestedAttributeHelper
|
2
|
+
def init_nested_attributes(reflections)
|
3
|
+
reflections.each do |r|
|
4
|
+
define_method("#{r}_attributes=") do |attr|
|
5
|
+
if attr.present?
|
6
|
+
children = []
|
7
|
+
attr.each do |child|
|
8
|
+
children << r.classify.constantize.find_or_initialize_by(child)
|
9
|
+
end
|
10
|
+
eval("self.#{r} = children")
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: dcidev_active_record
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.12
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Punto Damar P
|
@@ -19,6 +19,7 @@ extra_rdoc_files: []
|
|
19
19
|
files:
|
20
20
|
- README.md
|
21
21
|
- lib/dcidev_active_record.rb
|
22
|
+
- lib/nested_attribute_helper.rb
|
22
23
|
homepage:
|
23
24
|
licenses: []
|
24
25
|
metadata: {}
|