ecom_core 1.1.18 → 1.1.23
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/ecom/core/crew_overtime.rb +4 -4
- data/app/models/ecom/core/crew_time.rb +39 -13
- data/db/migrate/20200413144023_fix_crew_time_columns.rb +17 -0
- data/db/migrate/20200414044144_adjust_crew_overtime_column_names.rb +6 -0
- data/db/migrate/20200414185248_change_time_columns_to_datetime.rb +8 -0
- data/lib/ecom/core/version.rb +1 -1
- data/lib/ecom_core.rb +0 -1
- data/spec/factories/ecom/core/crew_overtimes.rb +1 -1
- data/spec/factories/ecom/core/crew_times.rb +3 -3
- metadata +16 -28
- data/db/data/20200401064242_move_date_to_attendance_sheet.rb +0 -20
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 780e3e5446f8c5f8fd0f11d3c526d62862dadec134466a68d288772803904081
|
4
|
+
data.tar.gz: '0478e2c6c16bb601d0fddce8d62c5fee45aafde7d0a97e33ff59939ae7973491'
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 6ecf8671c0c71aff50eac948d780a70fdba32c7cf8f785bbb36e25226feec70511c2ef36e341aa9efc79f3c016927a88c1992480da418862304ba3d2eddd34c5
|
7
|
+
data.tar.gz: 4ec0ae3be645dc45929b3107cac0d3340c13df45360fa3ee6cf60c10801fb76ba8b0d0588e672058ae5d56f194f4db12bbcceaa21adba791eac161fbf57907b2
|
@@ -8,13 +8,13 @@ module Ecom
|
|
8
8
|
|
9
9
|
has_one :revision, class_name: 'Ecom::Core::CrewOvertime', foreign_key: :revision_to_id
|
10
10
|
|
11
|
-
validates :hours, :
|
11
|
+
validates :hours, :raw_hours, presence: true
|
12
12
|
|
13
|
-
before_save :
|
13
|
+
before_save :calculate_hours
|
14
14
|
|
15
|
-
def
|
15
|
+
def calculate_hours
|
16
16
|
rate = OvertimeType.find(overtime_type_id).rate
|
17
|
-
self.
|
17
|
+
self.hours = raw_hours * rate
|
18
18
|
end
|
19
19
|
end
|
20
20
|
end
|
@@ -1,26 +1,52 @@
|
|
1
1
|
module Ecom
|
2
2
|
module Core
|
3
3
|
class CrewTime < ApplicationRecord
|
4
|
+
# Time Ranges
|
5
|
+
MORNING = 'Morning'.freeze
|
6
|
+
AFTERNOON = 'Afternoon'.freeze
|
7
|
+
BOTH = 'Both'.freeze
|
8
|
+
|
9
|
+
TIME_RANGE = {
|
10
|
+
MORNING => {start: Time.zone.parse('5:00 AM'), end: Time.zone.parse('9:00 AM')},
|
11
|
+
AFTERNOON => {start: Time.zone.parse('10:00 AM'), end: Time.zone.parse('2:00 PM')},
|
12
|
+
BOTH => {start: Time.zone.parse('5:00 AM'), end: Time.zone.parse('2:00 PM')}
|
13
|
+
}.freeze
|
14
|
+
|
4
15
|
belongs_to :attendance_sheet_entry
|
5
|
-
belongs_to :
|
16
|
+
belongs_to :revision_to, class_name: 'Ecom::Core::CrewTime', optional: true
|
17
|
+
belongs_to :created_by, class_name: 'Ecom::Core::User'
|
18
|
+
has_one :revision, class_name: 'Ecom::Core::CrewTime', foreign_key: :revision_to_id
|
19
|
+
|
20
|
+
validates :hours, presence: true
|
6
21
|
|
7
|
-
|
8
|
-
# validates_each :date do |record, attr, value|
|
9
|
-
# if record.crew && value && (value < record.crew.employment_date)
|
10
|
-
# record.errors.add(attr, 'should be after employment date')
|
11
|
-
# end
|
12
|
-
# end
|
22
|
+
before_save :calculate_hours
|
13
23
|
|
14
|
-
|
24
|
+
def calculate_hours
|
25
|
+
self.hours = checkout_time.nil? ? 0 : compute_hours
|
26
|
+
end
|
15
27
|
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
28
|
+
# A method to check if checkin and checkout range falls in the morning,
|
29
|
+
# afternoon, or both.
|
30
|
+
def find_range
|
31
|
+
if checkin_time.before?(TIME_RANGE[MORNING][:end]) && checkout_time.before?(TIME_RANGE[AFTERNOON][:start])
|
32
|
+
MORNING
|
33
|
+
elsif checkin_time.after?(TIME_RANGE[MORNING][:end]) && checkout_time.after?(TIME_RANGE[AFTERNOON][:start])
|
34
|
+
AFTERNOON
|
20
35
|
else
|
21
|
-
|
36
|
+
BOTH
|
22
37
|
end
|
23
38
|
end
|
39
|
+
|
40
|
+
# A method to adjust time ranges by trimming any time value outside
|
41
|
+
# of the defined morning and afternoon ranges
|
42
|
+
def compute_hours
|
43
|
+
range = find_range
|
44
|
+
left = checkin_time.before?(TIME_RANGE[range][:start]) ? TIME_RANGE[range][:start] : checkin_time
|
45
|
+
right = checkout_time.after?(TIME_RANGE[range][:end]) ? TIME_RANGE[range][:end] : checkout_time
|
46
|
+
time = (right - left) / 1.hour
|
47
|
+
time -= 1 if range == BOTH
|
48
|
+
time
|
49
|
+
end
|
24
50
|
end
|
25
51
|
end
|
26
52
|
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
class FixCrewTimeColumns < ActiveRecord::Migration[6.0]
|
2
|
+
def change
|
3
|
+
remove_column :ecom_core_crew_times, :overtime, :boolean
|
4
|
+
remove_column :ecom_core_crew_times, :overtime_type_id, :integer
|
5
|
+
remove_column :ecom_core_crew_times, :converted_hours, :float
|
6
|
+
|
7
|
+
add_column :ecom_core_crew_times, :revised, :boolean, default: false, null: false
|
8
|
+
add_column :ecom_core_crew_times, :revision_to_id, :integer
|
9
|
+
add_column :ecom_core_crew_times, :created_by_id, :integer
|
10
|
+
|
11
|
+
add_index :ecom_core_crew_times, :revision_to_id, name: 'ct_on_rt_indx'
|
12
|
+
add_index :ecom_core_crew_times, :created_by_id, name: 'cb_on_ct_indx'
|
13
|
+
|
14
|
+
add_foreign_key :ecom_core_crew_times, :ecom_core_crew_times, column: :revision_to_id
|
15
|
+
add_foreign_key :ecom_core_crew_times, :ecom_core_users, column: :created_by_id
|
16
|
+
end
|
17
|
+
end
|
@@ -0,0 +1,8 @@
|
|
1
|
+
class ChangeTimeColumnsToDatetime < ActiveRecord::Migration[6.0]
|
2
|
+
def change
|
3
|
+
remove_column :ecom_core_crew_times, :checkin_time, :time
|
4
|
+
add_column :ecom_core_crew_times, :checkin_time, :datetime
|
5
|
+
remove_column :ecom_core_crew_times, :checkout_time, :time
|
6
|
+
add_column :ecom_core_crew_times, :checkout_time, :datetime
|
7
|
+
end
|
8
|
+
end
|
data/lib/ecom/core/version.rb
CHANGED
data/lib/ecom_core.rb
CHANGED
@@ -3,10 +3,10 @@ FactoryBot.define do
|
|
3
3
|
checkin_time { Time.now }
|
4
4
|
checkout_time { Time.now + 2 * 60 * 60 }
|
5
5
|
hours { 2 }
|
6
|
-
converted_hours { 2 }
|
7
6
|
remark { FFaker::Name.name }
|
8
|
-
overtime { false }
|
9
|
-
overtime_type { nil }
|
10
7
|
association :attendance_sheet_entry
|
8
|
+
revised { false }
|
9
|
+
revision_to { nil }
|
10
|
+
association :created_by, factory: :user
|
11
11
|
end
|
12
12
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ecom_core
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.1.
|
4
|
+
version: 1.1.23
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Henock L.
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-04-
|
11
|
+
date: 2020-04-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: aasm
|
@@ -25,21 +25,21 @@ dependencies:
|
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: '0'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
|
-
name:
|
28
|
+
name: active_model_serializers
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- - "
|
31
|
+
- - "~>"
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version:
|
33
|
+
version: 0.10.0
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- - "
|
38
|
+
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version:
|
40
|
+
version: 0.10.0
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
|
-
name:
|
42
|
+
name: ancestry
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
45
|
- - ">="
|
@@ -53,19 +53,19 @@ dependencies:
|
|
53
53
|
- !ruby/object:Gem::Version
|
54
54
|
version: '0'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
|
-
name:
|
56
|
+
name: bcrypt
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
|
-
- - "
|
59
|
+
- - ">="
|
60
60
|
- !ruby/object:Gem::Version
|
61
|
-
version: 0
|
61
|
+
version: '0'
|
62
62
|
type: :runtime
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
|
-
- - "
|
66
|
+
- - ">="
|
67
67
|
- !ruby/object:Gem::Version
|
68
|
-
version: 0
|
68
|
+
version: '0'
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: jwt
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
@@ -94,20 +94,6 @@ dependencies:
|
|
94
94
|
- - "~>"
|
95
95
|
- !ruby/object:Gem::Version
|
96
96
|
version: 6.0.2
|
97
|
-
- !ruby/object:Gem::Dependency
|
98
|
-
name: data_migrate
|
99
|
-
requirement: !ruby/object:Gem::Requirement
|
100
|
-
requirements:
|
101
|
-
- - ">="
|
102
|
-
- !ruby/object:Gem::Version
|
103
|
-
version: '0'
|
104
|
-
type: :runtime
|
105
|
-
prerelease: false
|
106
|
-
version_requirements: !ruby/object:Gem::Requirement
|
107
|
-
requirements:
|
108
|
-
- - ">="
|
109
|
-
- !ruby/object:Gem::Version
|
110
|
-
version: '0'
|
111
97
|
- !ruby/object:Gem::Dependency
|
112
98
|
name: factory_bot_rails
|
113
99
|
requirement: !ruby/object:Gem::Requirement
|
@@ -264,7 +250,6 @@ files:
|
|
264
250
|
- app/services/ecom/core/token_auth_service.rb
|
265
251
|
- config/database.ci.yml
|
266
252
|
- config/routes.rb
|
267
|
-
- db/data/20200401064242_move_date_to_attendance_sheet.rb
|
268
253
|
- db/migrate/20190101112620_create_ecom_core_lookups.rb
|
269
254
|
- db/migrate/20190101112625_create_ecom_core_overtime_types.rb
|
270
255
|
- db/migrate/20191119010518_create_ecom_core_task_template_types.rb
|
@@ -309,6 +294,9 @@ files:
|
|
309
294
|
- db/migrate/20200410090701_create_ecom_core_overtime_sheets.rb
|
310
295
|
- db/migrate/20200410100035_create_ecom_core_overtime_sheet_entries.rb
|
311
296
|
- db/migrate/20200410111827_create_ecom_core_crew_overtimes.rb
|
297
|
+
- db/migrate/20200413144023_fix_crew_time_columns.rb
|
298
|
+
- db/migrate/20200414044144_adjust_crew_overtime_column_names.rb
|
299
|
+
- db/migrate/20200414185248_change_time_columns_to_datetime.rb
|
312
300
|
- lib/ecom/core.rb
|
313
301
|
- lib/ecom/core/engine.rb
|
314
302
|
- lib/ecom/core/version.rb
|
@@ -1,20 +0,0 @@
|
|
1
|
-
class MoveDateToAttendanceSheet < ActiveRecord::Migration[6.0]
|
2
|
-
def up
|
3
|
-
dates = Ecom::Core::CrewTime.pluck('DISTINCT date(date)')
|
4
|
-
|
5
|
-
return if dates.count.zero?
|
6
|
-
|
7
|
-
attendances = []
|
8
|
-
dates.each do |date|
|
9
|
-
attendances << Ecom::Core::AttendanceSheet.new(date: date)
|
10
|
-
end
|
11
|
-
|
12
|
-
Ecom::Core::AttendanceSheet.transaction do
|
13
|
-
attendances.each(&:save)
|
14
|
-
end
|
15
|
-
end
|
16
|
-
|
17
|
-
def down
|
18
|
-
raise ActiveRecord::IrreversibleMigration
|
19
|
-
end
|
20
|
-
end
|