work_md 0.2.7 → 0.3.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 +4 -4
- data/bin/work_md +1 -0
- data/lib/work_md.rb +1 -0
- data/lib/work_md/cli.rb +6 -6
- data/lib/work_md/commands/config.rb +35 -0
- data/lib/work_md/commands/parse.rb +9 -2
- data/lib/work_md/commands/tyesterday.rb +6 -2
- data/lib/work_md/config.rb +13 -2
- data/lib/work_md/file.rb +40 -31
- data/lib/work_md/parser/engine.rb +13 -4
- data/lib/work_md/version.rb +1 -1
- metadata +3 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 11398053e95da7ddd262275d8df76965fdf1eadce26a7854a1b1c1b63ab04f43
|
4
|
+
data.tar.gz: a3fb3c6ccb1ff57f9597ac2ac7b42031284fb3e17e6d229248c8bdf7270d7afc
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 94d7ca6109f744ecc6e7042a78a154a79bbd6dd5e4fe209b09ca5e5911628644cc417f7e6066c6b3abaf2ba945178ef83f1cb0f79987dbed12352f63871974ed
|
7
|
+
data.tar.gz: f18458c73cfbcf5d5838d7e9fdaa0d3bc39cd6b102abe80c4c61e34a62473a39d18ea334d76df684a258f5a0f099736c1011a63756c59f950b0f830d8a0b9f9c
|
data/bin/work_md
CHANGED
data/lib/work_md.rb
CHANGED
@@ -4,6 +4,7 @@ require_relative 'work_md/version'
|
|
4
4
|
require_relative 'work_md/config'
|
5
5
|
require_relative 'work_md/file'
|
6
6
|
require_relative 'work_md/commands/today'
|
7
|
+
require_relative 'work_md/commands/config'
|
7
8
|
require_relative 'work_md/commands/yesterday'
|
8
9
|
require_relative 'work_md/commands/tyesterday'
|
9
10
|
require_relative 'work_md/parser/engine'
|
data/lib/work_md/cli.rb
CHANGED
@@ -9,11 +9,10 @@ module WorkMd
|
|
9
9
|
't' => 'today',
|
10
10
|
'ty' => 'tyesterday',
|
11
11
|
'y' => 'yesterday',
|
12
|
+
'c' => 'config',
|
12
13
|
'p' => 'parse'
|
13
14
|
}.freeze
|
14
15
|
|
15
|
-
DEFAULT_COMMAND = WorkMd::Commands::Today
|
16
|
-
|
17
16
|
def self.execute(argv)
|
18
17
|
first_argv_argument = argv.shift
|
19
18
|
|
@@ -26,17 +25,17 @@ module WorkMd
|
|
26
25
|
.const_get("WorkMd::Commands::#{command}")
|
27
26
|
.send(:execute, argv)
|
28
27
|
rescue NameError
|
29
|
-
puts
|
28
|
+
puts help(
|
30
29
|
::TTY::Box.frame(
|
31
30
|
"Command '#{first_argv_argument}' not found!",
|
32
31
|
**error_frame_style
|
33
32
|
)
|
34
33
|
)
|
35
34
|
rescue CommandMissing
|
36
|
-
|
35
|
+
help('Welcome! =)')
|
37
36
|
end
|
38
37
|
|
39
|
-
def self.
|
38
|
+
def self.help(message = '')
|
40
39
|
# rubocop:disable Layout/LineLength
|
41
40
|
puts ::TTY::Box.frame(
|
42
41
|
message,
|
@@ -49,8 +48,9 @@ module WorkMd
|
|
49
48
|
'- work_md yesterday',
|
50
49
|
'- work_md tyesterday',
|
51
50
|
'- work_md parse',
|
51
|
+
'- work_md config',
|
52
52
|
'',
|
53
|
-
'
|
53
|
+
'more information in github.com/henriquefernandez/work_md',
|
54
54
|
padding: 1,
|
55
55
|
title: { top_left: '(work_md)', bottom_right: "(v#{WorkMd::VERSION})" }
|
56
56
|
)
|
@@ -0,0 +1,35 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module WorkMd
|
4
|
+
module Commands
|
5
|
+
class Config
|
6
|
+
class << self
|
7
|
+
def execute(_argv = [])
|
8
|
+
file_name = 'config.yml'
|
9
|
+
work_dir = ::WorkMd::Config::DEFAULT_WORK_DIR
|
10
|
+
|
11
|
+
unless ::File.exist?("#{work_dir}/#{file_name}")
|
12
|
+
::FileUtils.mkdir_p(work_dir)
|
13
|
+
|
14
|
+
::File.open("#{work_dir}/#{file_name}", 'w+') do |f|
|
15
|
+
f.puts("# Example configuration:")
|
16
|
+
f.puts("#")
|
17
|
+
f.puts("# title: Your Name")
|
18
|
+
f.puts("# editor: vim")
|
19
|
+
f.puts("# lang: en")
|
20
|
+
f.puts("#")
|
21
|
+
f.puts("title: # Title your work_md files")
|
22
|
+
f.puts("editor: # Your default editor")
|
23
|
+
f.puts("lang: # Only 'pt', 'en' and 'es' avaiable")
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
::WorkMd::File.open_in_editor(
|
28
|
+
file_names: [file_name],
|
29
|
+
dir: work_dir
|
30
|
+
)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -65,7 +65,14 @@ module WorkMd
|
|
65
65
|
end
|
66
66
|
f.puts("---\n\n")
|
67
67
|
f.puts("### #{t[:pomodoros]} (#{parser.average_pomodoros} #{t[:per_day]}):\n\n")
|
68
|
-
f.puts(parser.
|
68
|
+
f.puts(parser.pomodoros_sum)
|
69
|
+
f.puts("\n\n")
|
70
|
+
|
71
|
+
parser.pomodoros_bars.each do |pomodoro_bar|
|
72
|
+
f.puts(pomodoro_bar)
|
73
|
+
f.puts("\n\n")
|
74
|
+
end
|
75
|
+
f.puts("\n\n")
|
69
76
|
end
|
70
77
|
|
71
78
|
editor = WorkMd::Config.editor
|
@@ -76,7 +83,7 @@ module WorkMd
|
|
76
83
|
::TTY::Editor.open(PARSED_FILE_PATH)
|
77
84
|
end
|
78
85
|
rescue => e
|
79
|
-
WorkMd::Cli.
|
86
|
+
WorkMd::Cli.help(
|
80
87
|
::TTY::Box.frame(
|
81
88
|
"message: #{e.message}",
|
82
89
|
"",
|
@@ -5,8 +5,12 @@ module WorkMd
|
|
5
5
|
class Tyesterday
|
6
6
|
class << self
|
7
7
|
def execute(_argv = [])
|
8
|
-
|
9
|
-
|
8
|
+
file_names =
|
9
|
+
[DateTime.now, Date.today.prev_day].map do |date|
|
10
|
+
WorkMd::File.create_if_not_exist(date)
|
11
|
+
end
|
12
|
+
|
13
|
+
WorkMd::File.open_in_editor(file_names: file_names)
|
10
14
|
end
|
11
15
|
end
|
12
16
|
end
|
data/lib/work_md/config.rb
CHANGED
@@ -4,7 +4,7 @@ require 'yaml'
|
|
4
4
|
|
5
5
|
module WorkMd
|
6
6
|
module Config
|
7
|
-
DEFAULT_WORK_DIR = Dir.home
|
7
|
+
DEFAULT_WORK_DIR = "#{Dir.home}/work_md"
|
8
8
|
TRANSLATIONS = {
|
9
9
|
'pt' =>
|
10
10
|
{
|
@@ -25,7 +25,18 @@ module WorkMd
|
|
25
25
|
observations: 'Observations',
|
26
26
|
pomodoros: 'Pomodoros / Cycles',
|
27
27
|
per_day: 'per day'
|
28
|
+
},
|
29
|
+
'es' =>
|
30
|
+
{
|
31
|
+
tasks: 'Tareas',
|
32
|
+
meetings: 'Reuniones',
|
33
|
+
interruptions: 'Interrupciones',
|
34
|
+
difficulties: 'Dificultades',
|
35
|
+
observations: 'Observaciones',
|
36
|
+
pomodoros: 'Pomodoros / Ciclos',
|
37
|
+
per_day: 'por día'
|
28
38
|
}
|
39
|
+
|
29
40
|
}.freeze
|
30
41
|
|
31
42
|
def self.title
|
@@ -47,7 +58,7 @@ module WorkMd
|
|
47
58
|
end
|
48
59
|
|
49
60
|
def self.yaml_file
|
50
|
-
YAML.load_file(DEFAULT_WORK_DIR
|
61
|
+
YAML.load_file("#{DEFAULT_WORK_DIR}/config.yml")
|
51
62
|
rescue StandardError
|
52
63
|
{}
|
53
64
|
end
|
data/lib/work_md/file.rb
CHANGED
@@ -3,47 +3,56 @@
|
|
3
3
|
module WorkMd
|
4
4
|
class File
|
5
5
|
def self.open_or_create(some_date)
|
6
|
+
open_in_editor(file_names: [create_if_not_exist(some_date)])
|
7
|
+
end
|
8
|
+
|
9
|
+
def self.create_if_not_exist(some_date)
|
6
10
|
t = WorkMd::Config.translations
|
7
11
|
work_dir = WorkMd::Config.work_dir
|
8
12
|
|
13
|
+
file_name = "#{some_date.strftime('%Y/%m/%d')}.md"
|
14
|
+
|
15
|
+
return file_name if ::File.exist?("#{work_dir}/#{file_name}")
|
16
|
+
|
9
17
|
::FileUtils
|
10
18
|
.mkdir_p("#{work_dir}/#{some_date.strftime('%Y/%m')}")
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
end
|
19
|
+
|
20
|
+
::File.open(
|
21
|
+
"#{work_dir}/#{file_name}",
|
22
|
+
'w+'
|
23
|
+
) do |f|
|
24
|
+
# rubocop:disable Layout/LineLength
|
25
|
+
f.puts("# #{some_date.strftime('%d/%m/%Y')} - #{WorkMd::Config.title} \n\n")
|
26
|
+
# rubocop:enable Layout/LineLength
|
27
|
+
f.puts("### #{t[:tasks]}:\n\n")
|
28
|
+
f.puts("- [ ]\n\n")
|
29
|
+
f.puts("---\n\n")
|
30
|
+
f.puts("### #{t[:meetings]}:\n\n")
|
31
|
+
f.puts("- [ ]\n\n")
|
32
|
+
f.puts("---\n\n")
|
33
|
+
f.puts("### #{t[:interruptions]}:\n\n")
|
34
|
+
f.puts("---\n\n")
|
35
|
+
f.puts("### #{t[:difficulties]}:\n\n")
|
36
|
+
f.puts("---\n\n")
|
37
|
+
f.puts("### #{t[:observations]}:\n\n")
|
38
|
+
f.puts("---\n\n")
|
39
|
+
f.puts("### #{t[:pomodoros]}:\n\n")
|
40
|
+
f.puts("0\n\n")
|
34
41
|
end
|
35
42
|
|
43
|
+
file_name
|
44
|
+
end
|
45
|
+
|
46
|
+
def self.open_in_editor(file_names: [], dir: nil)
|
36
47
|
editor = WorkMd::Config.editor
|
48
|
+
work_dir = dir || WorkMd::Config.work_dir
|
37
49
|
|
38
50
|
::FileUtils.cd(work_dir) do
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
command: editor
|
45
|
-
)
|
46
|
-
end
|
51
|
+
ENV['EDITOR'] = editor unless editor.nil?
|
52
|
+
|
53
|
+
return ::TTY::Editor.open(file_names[0]) if file_names[1].nil?
|
54
|
+
|
55
|
+
::TTY::Editor.open(file_names[0], file_names[1])
|
47
56
|
end
|
48
57
|
end
|
49
58
|
end
|
@@ -75,20 +75,29 @@ module WorkMd
|
|
75
75
|
end
|
76
76
|
|
77
77
|
def average_pomodoros
|
78
|
-
if @parsed_files.size.positive? &&
|
79
|
-
return (
|
78
|
+
if @parsed_files.size.positive? && pomodoros_sum.positive?
|
79
|
+
return (pomodoros_sum.to_f / @parsed_files.size).round(1)
|
80
80
|
end
|
81
81
|
|
82
82
|
0
|
83
83
|
end
|
84
84
|
|
85
|
-
def
|
85
|
+
def pomodoros_sum
|
86
86
|
raise IS_NOT_FROZEN_ERROR_MESSAGE unless @frozen
|
87
87
|
|
88
|
-
@
|
88
|
+
@pomodoros_sum ||=
|
89
89
|
@parsed_files.reduce(0) { |sum, f| sum + f.pomodoros || 0 }
|
90
90
|
end
|
91
91
|
|
92
|
+
def pomodoros_bars
|
93
|
+
raise IS_NOT_FROZEN_ERROR_MESSAGE unless @frozen
|
94
|
+
|
95
|
+
@pomodoros_bars ||=
|
96
|
+
@parsed_files.map do |f|
|
97
|
+
"(#{f.date}) #{(1..f.pomodoros).map { '◘' }.join}"
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
92
101
|
def freeze
|
93
102
|
@frozen = true
|
94
103
|
end
|
data/lib/work_md/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: work_md
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.3.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Henrique Fernandez Teixeira
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-08-
|
11
|
+
date: 2021-08-16 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: tty-box
|
@@ -51,6 +51,7 @@ files:
|
|
51
51
|
- bin/work_md
|
52
52
|
- lib/work_md.rb
|
53
53
|
- lib/work_md/cli.rb
|
54
|
+
- lib/work_md/commands/config.rb
|
54
55
|
- lib/work_md/commands/parse.rb
|
55
56
|
- lib/work_md/commands/today.rb
|
56
57
|
- lib/work_md/commands/tyesterday.rb
|