ecom_core 1.1.11 → 1.1.16

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: ac844133bce138559e3a84c51b8f617a42cbcfed66935835693e9478230cc682
4
- data.tar.gz: 1416a37521f375b4b4432816661fa7f71dc1e9859c4822b4c63dc692bf144f57
3
+ metadata.gz: fe250f7096d4de2dbcce2ab0e9ad159f107812cf69768fa6cd92962c8c80c937
4
+ data.tar.gz: 29bba333d43472d8339ad18a0ecd9e238a72b705c13fd86ae283ac095d9adf0b
5
5
  SHA512:
6
- metadata.gz: 0244a00f0335429ea1810c615ecaa7f4d934f8f2ab0cca46da585c576b4420acd45606cb0f11f6cd060009e292bbc47564f4761a9823f6a2751789f77c50b25d
7
- data.tar.gz: e17dc48bf97da94e12e824099e70d3a86f5aa6600fb67507278afba74eae7bdad6c5bade2dcaf2a9cb23936856be98b98a953ed863df776df3ab56e48e07bed8
6
+ metadata.gz: 981a42e43a0beeef91423b2f282c2908dd516d1c4ee56d5ad55cf6275221f3962e2ba1eacb7861d63bdb5ae4805041f1e786f321473696f540c927b8c8472b8f
7
+ data.tar.gz: 2a84218270b5001b34d02c16e4a5c6cfc6fc0e9d47651389e2851524bf4e6910dc8e99b6578e2d52dd7996802c06953f266034df6652a42c97c8e6608e48f162
@@ -2,14 +2,20 @@ module Ecom
2
2
  module Core
3
3
  class AttendanceSheet < ApplicationRecord
4
4
  OPEN = 'Open'.freeze
5
- CLOSED = 'Closed'.freeze
5
+ SUBMITTED = 'Submitted'.freeze
6
+ APPROVED = 'Approved'.freeze
6
7
 
7
8
  validates :date, :opened_at, presence: true, uniqueness: true
8
- validates :status, inclusion: [OPEN, CLOSED]
9
+ validates :status, inclusion: [OPEN, SUBMITTED, APPROVED]
9
10
 
10
11
  has_many :attendance_sheet_entries
11
12
 
12
13
  scope :open, -> { find_by(status: OPEN) }
14
+ scope :current_open, -> { where(status: OPEN, date: Date.today) }
15
+
16
+ def self.open_exists?
17
+ AttendanceSheet.where(status: OPEN).exists?
18
+ end
13
19
 
14
20
  def self.exists_for_today?
15
21
  AttendanceSheet.where(date: Date.today).exists?
@@ -27,31 +33,33 @@ module Ecom
27
33
  def self.create_current
28
34
  raise 'Attendance sheet already created for the day.' if AttendanceSheet.exists_for_today?
29
35
 
36
+ raise 'There is an open attendance sheet which needs to be submitted before creating a new one.' if AttendanceSheet.open_exists?
37
+
30
38
  AttendanceSheet.create(date: Date.today, opened_at: Time.now, status: OPEN)
31
39
  end
32
40
 
33
- def self.close_current
41
+ def self.submit_current
34
42
  sheet = AttendanceSheet.find_by(date: Date.today, status: OPEN)
35
43
 
36
- raise 'There is no attendance sheet to close.' if sheet.nil?
44
+ raise 'There is no open attendance sheet to submit.' if sheet.nil?
37
45
 
38
46
  sheet.closed_at = Time.now
39
- sheet.status = CLOSED
47
+ sheet.status = SUBMITTED
40
48
  sheet.save
41
49
  sheet
42
50
  end
43
51
 
44
52
  # This method should be used by privileged users
45
- # to close the attendance sheet after the date has
53
+ # to submit the attendance sheet after the date has
46
54
  # passed. Normally, timekeepers need to open and close
47
55
  # an attendance sheet of a date on the specific date.
48
- def self.close
49
- raise 'There is no attendance sheet to close.' unless AttendanceSheet.open_exists_for_today?
56
+ def submit
57
+ raise 'This attendance sheet is not open. Therefore it cannot be submitted' unless status == OPEN
50
58
 
51
- sheet = AttendanceSheet.open
52
- sheet.closed_at = Time.now
53
- sheet.save
54
- sheet
59
+ self.closed_at = Time.now
60
+ self.status = SUBMITTED
61
+ save
62
+ self
55
63
  end
56
64
  end
57
65
  end
@@ -3,6 +3,7 @@ module Ecom
3
3
  class AttendanceSheetEntry < ApplicationRecord
4
4
  belongs_to :attendance_sheet
5
5
  belongs_to :crew
6
+ has_many :crew_times
6
7
  end
7
8
  end
8
9
  end
@@ -9,13 +9,13 @@ module Ecom
9
9
  SQL
10
10
  menu = Menu.joins(join_sql).where('UR.id IN (?)', role_ids).distinct
11
11
  menu_list = menu.select { |m| m.parent.nil? }.each_with_object([]) do |item, list|
12
- list << { id: item.id, label: item.label, icon: item.icon, items: [] }
12
+ list << { id: item.id, label: item.label, icon: item.icon, children: [] }
13
13
  end
14
14
 
15
15
  menu_list.each do |ml|
16
- ml[:items] = menu.reject { |m| m.parent.nil? }.each_with_object([]) do |item, list|
16
+ ml[:children] = menu.reject { |m| m.parent.nil? }.each_with_object([]) do |item, list|
17
17
  if item.parent_id == ml[:id]
18
- list << { id: item.id, label: item.label, icon: item.icon, routerLink: item.route }
18
+ list << { id: item.id, label: item.label, icon: item.icon, route: item.route }
19
19
  end
20
20
  end
21
21
  end
@@ -1,5 +1,5 @@
1
1
  module Ecom
2
2
  module Core
3
- VERSION = '1.1.11'.freeze
3
+ VERSION = '1.1.16'.freeze
4
4
  end
5
5
  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.11
4
+ version: 1.1.16
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-02 00:00:00.000000000 Z
11
+ date: 2020-04-10 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: aasm