checkoff 0.110.0 → 0.111.0
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/Gemfile.lock +1 -1
- data/lib/checkoff/internal/ready_between_relative.rb +4 -4
- data/lib/checkoff/internal/selector_classes/task.rb +2 -61
- data/lib/checkoff/internal/task_timing.rb +29 -1
- data/lib/checkoff/tasks.rb +11 -2
- data/lib/checkoff/timing.rb +27 -2
- data/lib/checkoff/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6e758f72d1a6f7cd1c2dd5b6ebb4b52964e9fa2ee6e24f9e17aa613f6c6fe23b
|
4
|
+
data.tar.gz: 9354f3874da0b13ec8662042475d60f67d0b67be9d22ddca07ee9938e81777f0
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 6d5945f70f231c337708a252597ffb2623c9fdc7e96996ca1acfe6337ac1082f53fd3fcc2fc0ae8fcab75c3af4b0eed5e8e469eb8ef0537558d1dfb4e5e56d36
|
7
|
+
data.tar.gz: e84eda5a4713bea660373ff2fc3829d861f61e4d88dd71b9127be5e077d0c9ca621fff32ec067e4890d37d1c65c67a47952f9e8478e129b3f2eae7a1c77443a6
|
data/Gemfile.lock
CHANGED
@@ -5,14 +5,14 @@ module Checkoff
|
|
5
5
|
# Determine whether a task is due within a relative date range
|
6
6
|
class ReadyBetweenRelative
|
7
7
|
# @param config [Hash<Symbol, Object>]
|
8
|
-
# @param
|
8
|
+
# @param client [Asana::Client]
|
9
9
|
# @param task_timing [Checkoff::Internal::TaskTiming]
|
10
10
|
# @param tasks [Checkoff::Tasks]
|
11
11
|
def initialize(config: Checkoff::Internal::ConfigLoader.load(:asana),
|
12
|
-
|
13
|
-
task_timing: ::Checkoff::Internal::TaskTiming.new,
|
12
|
+
client: Checkoff::Clients.new(config: config).client,
|
13
|
+
task_timing: ::Checkoff::Internal::TaskTiming.new(client: client),
|
14
14
|
tasks: ::Checkoff::Tasks.new(config: config,
|
15
|
-
client:
|
15
|
+
client: client))
|
16
16
|
@task_timing = task_timing
|
17
17
|
@tasks = tasks
|
18
18
|
end
|
@@ -166,73 +166,14 @@ module Checkoff
|
|
166
166
|
#
|
167
167
|
# @return [Boolean]
|
168
168
|
def evaluate(task, beginning_num_days_from_now, end_num_days_from_now, ignore_dependencies: false)
|
169
|
-
ready_between_relative = Checkoff::Internal::ReadyBetweenRelative.new(tasks: @tasks
|
169
|
+
ready_between_relative = Checkoff::Internal::ReadyBetweenRelative.new(tasks: @tasks,
|
170
|
+
client: @client)
|
170
171
|
ready_between_relative.ready_between_relative?(task,
|
171
172
|
beginning_num_days_from_now, end_num_days_from_now,
|
172
173
|
ignore_dependencies: ignore_dependencies)
|
173
174
|
end
|
174
175
|
end
|
175
176
|
|
176
|
-
# :custom_field_less_than_n_days_from_now function
|
177
|
-
class CustomFieldLessThanNDaysFromNowFunctionEvaluator < FunctionEvaluator
|
178
|
-
FUNCTION_NAME = :custom_field_less_than_n_days_from_now
|
179
|
-
|
180
|
-
def matches?
|
181
|
-
fn?(selector, FUNCTION_NAME)
|
182
|
-
end
|
183
|
-
|
184
|
-
def evaluate_arg?(_index)
|
185
|
-
false
|
186
|
-
end
|
187
|
-
|
188
|
-
# @param task [Asana::Resources::Task]
|
189
|
-
# @param custom_field_name [String]
|
190
|
-
# @param num_days [Integer]
|
191
|
-
# @return [Boolean]
|
192
|
-
def evaluate(task, custom_field_name, num_days)
|
193
|
-
custom_field = @custom_fields.resource_custom_field_by_name_or_raise(task, custom_field_name)
|
194
|
-
|
195
|
-
# @sg-ignore
|
196
|
-
# @type [String, nil]
|
197
|
-
time_str = custom_field.fetch('display_value')
|
198
|
-
return false if time_str.nil?
|
199
|
-
|
200
|
-
time = Time.parse(time_str)
|
201
|
-
n_days_from_now = (Time.now + (num_days * 24 * 60 * 60))
|
202
|
-
time < n_days_from_now
|
203
|
-
end
|
204
|
-
end
|
205
|
-
|
206
|
-
# :custom_field_greater_than_or_equal_to_n_days_from_now function
|
207
|
-
class CustomFieldGreaterThanOrEqualToNDaysFromNowFunctionEvaluator < FunctionEvaluator
|
208
|
-
FUNCTION_NAME = :custom_field_greater_than_or_equal_to_n_days_from_now
|
209
|
-
|
210
|
-
def matches?
|
211
|
-
fn?(selector, FUNCTION_NAME)
|
212
|
-
end
|
213
|
-
|
214
|
-
def evaluate_arg?(_index)
|
215
|
-
false
|
216
|
-
end
|
217
|
-
|
218
|
-
# @param task [Asana::Resources::Task]
|
219
|
-
# @param custom_field_name [String]
|
220
|
-
# @param num_days [Integer]
|
221
|
-
# @return [Boolean]
|
222
|
-
def evaluate(task, custom_field_name, num_days)
|
223
|
-
custom_field = @custom_fields.resource_custom_field_by_name_or_raise(task, custom_field_name)
|
224
|
-
|
225
|
-
# @sg-ignore
|
226
|
-
# @type [String, nil]
|
227
|
-
time_str = custom_field.fetch('display_value')
|
228
|
-
return false if time_str.nil?
|
229
|
-
|
230
|
-
time = Time.parse(time_str)
|
231
|
-
n_days_from_now = (Time.now + (num_days * 24 * 60 * 60))
|
232
|
-
time >= n_days_from_now
|
233
|
-
end
|
234
|
-
end
|
235
|
-
|
236
177
|
# :last_story_created_less_than_n_days_ago function
|
237
178
|
class LastStoryCreatedLessThanNDaysAgoFunctionEvaluator < FunctionEvaluator
|
238
179
|
FUNCTION_NAME = :last_story_created_less_than_n_days_ago
|
@@ -6,9 +6,14 @@ module Checkoff
|
|
6
6
|
class TaskTiming
|
7
7
|
# @param time_class [Class<Time>]
|
8
8
|
# @param date_class [Class<Date>]
|
9
|
-
|
9
|
+
# @param client [Asana::Client]
|
10
|
+
# @param custom_fields [Checkoff::CustomFields]
|
11
|
+
def initialize(time_class: Time, date_class: Date,
|
12
|
+
client: Checkoff::Clients.new.client,
|
13
|
+
custom_fields: Checkoff::CustomFields.new(client: client))
|
10
14
|
@time_class = time_class
|
11
15
|
@date_class = date_class
|
16
|
+
@custom_fields = custom_fields
|
12
17
|
end
|
13
18
|
|
14
19
|
# @param task [Asana::Resources::Task]
|
@@ -56,6 +61,20 @@ module Checkoff
|
|
56
61
|
return @time_class.parse(task.modified_at) unless task.modified_at.nil?
|
57
62
|
end
|
58
63
|
|
64
|
+
# @param task [Asana::Resources::Task]
|
65
|
+
# @param custom_field_name [String]
|
66
|
+
#
|
67
|
+
# @return [Time, Date, nil]
|
68
|
+
def custom_field(task, custom_field_name)
|
69
|
+
custom_field = @custom_fields.resource_custom_field_by_name_or_raise(task, custom_field_name)
|
70
|
+
# @sg-ignore
|
71
|
+
# @type [String, nil]
|
72
|
+
time_str = custom_field.fetch('display_value')
|
73
|
+
return nil if time_str.nil?
|
74
|
+
|
75
|
+
Time.parse(time_str)
|
76
|
+
end
|
77
|
+
|
59
78
|
# @param task [Asana::Resources::Task]
|
60
79
|
# @param field_name [Symbol]
|
61
80
|
#
|
@@ -70,6 +89,15 @@ module Checkoff
|
|
70
89
|
|
71
90
|
return start_date_or_time(task) || due_date_or_time(task) if field_name == :ready
|
72
91
|
|
92
|
+
if field_name.is_a?(Array)
|
93
|
+
# @sg-ignore
|
94
|
+
# @type [Symbol]
|
95
|
+
actual_field_name = field_name.first
|
96
|
+
args = field_name[1..]
|
97
|
+
|
98
|
+
return custom_field(task, *args) if actual_field_name == :custom_field
|
99
|
+
end
|
100
|
+
|
73
101
|
raise "Teach me how to handle field #{field_name}"
|
74
102
|
end
|
75
103
|
end
|
data/lib/checkoff/tasks.rb
CHANGED
@@ -28,6 +28,7 @@ module Checkoff
|
|
28
28
|
# @param workspaces [Checkoff::Workspaces]
|
29
29
|
# @param sections [Checkoff::Sections]
|
30
30
|
# @param portfolios [Checkoff::Portfolios]
|
31
|
+
# @param custom_fields [Checkoff::CustomFields]
|
31
32
|
# @param time_class [Class<Time>]
|
32
33
|
# @param date_class [Class<Date>]
|
33
34
|
# @param asana_task [Class<Asana::Resources::Task>]
|
@@ -39,6 +40,8 @@ module Checkoff
|
|
39
40
|
client: client),
|
40
41
|
portfolios: Checkoff::Portfolios.new(config: config,
|
41
42
|
client: client),
|
43
|
+
custom_fields: Checkoff::CustomFields.new(config: config,
|
44
|
+
client: client),
|
42
45
|
time_class: Time,
|
43
46
|
date_class: Date,
|
44
47
|
asana_task: Asana::Resources::Task)
|
@@ -49,6 +52,7 @@ module Checkoff
|
|
49
52
|
@asana_task = asana_task
|
50
53
|
@client = client
|
51
54
|
@portfolios = portfolios
|
55
|
+
@custom_fields = custom_fields
|
52
56
|
@workspaces = workspaces
|
53
57
|
@timing = Timing.new(today_getter: date_class, now_getter: time_class)
|
54
58
|
end
|
@@ -73,7 +77,7 @@ module Checkoff
|
|
73
77
|
end
|
74
78
|
|
75
79
|
# @param task [Asana::Resources::Task]
|
76
|
-
# @param field_name [Symbol]
|
80
|
+
# @param field_name [Symbol,Array]
|
77
81
|
# @param period [Symbol<:now_or_before,:this_week>,Array] See Checkoff::Timing#in_period?_
|
78
82
|
def in_period?(task, field_name, period)
|
79
83
|
# @type [Date,Time,nil]
|
@@ -210,7 +214,9 @@ module Checkoff
|
|
210
214
|
|
211
215
|
# @return [Checkoff::Internal::TaskTiming]
|
212
216
|
def task_timing
|
213
|
-
@task_timing ||= Checkoff::Internal::TaskTiming.new(time_class: @time_class, date_class: @date_class
|
217
|
+
@task_timing ||= Checkoff::Internal::TaskTiming.new(time_class: @time_class, date_class: @date_class,
|
218
|
+
client: client,
|
219
|
+
custom_fields: custom_fields)
|
214
220
|
end
|
215
221
|
|
216
222
|
# @return [Checkoff::Internal::TaskHashes]
|
@@ -246,6 +252,9 @@ module Checkoff
|
|
246
252
|
# @return [Checkoff::Timing]
|
247
253
|
attr_reader :timing
|
248
254
|
|
255
|
+
# @return [Checkoff::CustomFields]
|
256
|
+
attr_reader :custom_fields
|
257
|
+
|
249
258
|
# @return [Checkoff::Projects]
|
250
259
|
def projects
|
251
260
|
@projects ||= @sections.projects
|
data/lib/checkoff/timing.rb
CHANGED
@@ -68,6 +68,15 @@ module Checkoff
|
|
68
68
|
date >= n_days_from_today
|
69
69
|
end
|
70
70
|
|
71
|
+
# @param date_or_time [Date,Time,nil]
|
72
|
+
# @param num_days [Integer]
|
73
|
+
def greater_than_or_equal_to_n_days_from_now?(date_or_time, num_days)
|
74
|
+
return false if date_or_time.nil?
|
75
|
+
|
76
|
+
n_days_from_now = (@now_getter.now + (num_days * 24 * 60 * 60))
|
77
|
+
date_or_time >= n_days_from_now
|
78
|
+
end
|
79
|
+
|
71
80
|
# @param date_or_time [Date,Time,nil]
|
72
81
|
# @param num_days [Integer]
|
73
82
|
def less_than_n_days_ago?(date_or_time, num_days)
|
@@ -81,6 +90,15 @@ module Checkoff
|
|
81
90
|
date < n_days_ago
|
82
91
|
end
|
83
92
|
|
93
|
+
# @param date_or_time [Date,Time,nil]
|
94
|
+
# @param num_days [Integer]
|
95
|
+
def less_than_n_days_from_now?(date_or_time, num_days)
|
96
|
+
return false if date_or_time.nil?
|
97
|
+
|
98
|
+
n_days_from_now = (@now_getter.now + (num_days * 24 * 60 * 60))
|
99
|
+
date_or_time < n_days_from_now
|
100
|
+
end
|
101
|
+
|
84
102
|
# @param date_or_time [Date,Time,nil]
|
85
103
|
def this_week?(date_or_time)
|
86
104
|
return true if date_or_time.nil?
|
@@ -112,10 +130,17 @@ module Checkoff
|
|
112
130
|
# @sg-ignore
|
113
131
|
return less_than_n_days_ago?(date_or_time, *args) if period_name == :less_than_n_days_ago
|
114
132
|
|
133
|
+
return less_than_n_days_from_now?(date_or_time, *args) if period_name == :less_than_n_days_from_now
|
134
|
+
|
135
|
+
if period_name == :greater_than_or_equal_to_n_days_from_now
|
136
|
+
return greater_than_or_equal_to_n_days_from_now?(date_or_time,
|
137
|
+
*args)
|
138
|
+
end
|
139
|
+
|
115
140
|
if period_name == :greater_than_or_equal_to_n_days_from_today
|
116
|
-
return greater_than_or_equal_to_n_days_from_today?(date_or_time,
|
117
|
-
*args)
|
141
|
+
return greater_than_or_equal_to_n_days_from_today?(date_or_time, *args)
|
118
142
|
end
|
143
|
+
|
119
144
|
raise "Teach me how to handle period [#{period_name.inspect}, #{args.join(', ')}]"
|
120
145
|
end
|
121
146
|
|
data/lib/checkoff/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: checkoff
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.111.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Vince Broz
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-10-
|
11
|
+
date: 2023-10-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|