keyboard_reactor 0.0.5 → 0.0.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/keyboard_reactor/output.rb +14 -0
- data/lib/keyboard_reactor/version.rb +1 -1
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7baa8ff6a6866927ca12b9770e1074344458b3cb
|
4
|
+
data.tar.gz: dfd7bc77a16418812701221b2a6950a4115d0644
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 27d7bb9a274135c7344b201a06c93ab39d265b0c2f7b40a0b6a17348628ebfefe155277b7e3d209b8bfbe26db0441735b6c0389c569f30166c10364fadd01c33
|
7
|
+
data.tar.gz: 7518575a11a981ee23107e99d10aedb0826813455c03ff540f4812b7b613a1aecc91b4abd9394ffdc0fe0bda125b860a1658c82314955499fc860a01a9f1ba82
|
@@ -2,6 +2,7 @@ module KeyboardReactor
|
|
2
2
|
class Output
|
3
3
|
def initialize(keyboard_json = nil, keyboard_hash: nil)
|
4
4
|
@keyboard_hash = keyboard_hash || MultiJson.load(keyboard_json)
|
5
|
+
remap_keyboard_hash
|
5
6
|
@id = "#{(Time.now.to_f * 100).round}reactor"
|
6
7
|
end
|
7
8
|
|
@@ -16,6 +17,19 @@ module KeyboardReactor
|
|
16
17
|
COLUMNS.keys
|
17
18
|
end
|
18
19
|
|
20
|
+
def remap_keyboard_hash
|
21
|
+
# Because I don't know how to change the template to use `keys` instead of `keymap`
|
22
|
+
@keyboard_hash['layers'] = remapped_layers.select { |l| l['keymap'] && l['keymap'].any? }
|
23
|
+
end
|
24
|
+
|
25
|
+
def remapped_layers
|
26
|
+
return {} unless @keyboard_hash['layers']
|
27
|
+
@keyboard_hash['layers'].map do |layer|
|
28
|
+
layer['keymap'] = layer.delete('keys')
|
29
|
+
layer
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
19
33
|
def firmware_path
|
20
34
|
self.class.relative_path("firmware/keyboard/#{keyboard_kind}")
|
21
35
|
end
|