slack_widgets 0.2.4 → 0.3.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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 4278b252cbf84bf87fcc12b2187ca8d4b8854698
4
- data.tar.gz: 3f67866129072a623536ccf8689534b512a3b41f
3
+ metadata.gz: 660a9dc027de5350b85decc5bbc67cbf0e65b38b
4
+ data.tar.gz: 912c979839d1adcf7b9433b13cb6f92bdd54436f
5
5
  SHA512:
6
- metadata.gz: 98dff31fbb9d608baea76ffa6737d72dee9b8364ce624c6443016e02a51d6bda2e7862a3ab5358e841445dd28dbcf1e848a543a75afa31a56cd9b3f055757369
7
- data.tar.gz: 5dae7ea59f6416b817faccc5f72e0c5c604d8024b729f274a18150834cb81f1ecd83399cd2d9650f0d353ac41341aaa03dd22cdcf84bc8c12ecc413ddb558ea3
6
+ metadata.gz: 569cd6db75dbedfa2a899af9fbd12eea1063de191e806088cff77f1b8b1b9125ce640960fe1ec3f0acc118005f2151da10478b9808ed453c99880f08819d72bc
7
+ data.tar.gz: 667161d8fb9ad639fce6851caf384dc2580163860a81fde2d3c3fd6e2feb4251aebe0528e0e5c907ef7db256c3d0787ef6a384b0e6648adf61f75a8912d4057f
@@ -1,3 +1,3 @@
1
1
  module SlackWidgets
2
- VERSION = "0.2.4"
2
+ VERSION = "0.3.0"
3
3
  end
@@ -0,0 +1,27 @@
1
+ module SlackWidgets
2
+ class Dialog
3
+ def initialize(callback_id:, title:, submit_button_label:, elements:)
4
+ raise ArgumentError, 'elements must be an array of dialog widgets' unless elements.is_a?(Array)
5
+ @callback_id = callback_id
6
+ @title = title
7
+ @submit_button_label = submit_button_label
8
+ @elements = elements
9
+ end
10
+
11
+ def render
12
+ {
13
+ 'callback_id': @callback_id,
14
+ 'title': @title,
15
+ 'submit_label': @submit_button_label,
16
+ 'elements': @elements
17
+ }
18
+ end
19
+
20
+ def self.create(callback_id:, title:, submit_button_label:, elements:)
21
+ new(callback_id: callback_id,
22
+ title: title,
23
+ submit_button_label: submit_button_label,
24
+ elements: elements).render
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,26 @@
1
+ module SlackWidgets
2
+ class Dialog::DialogPicker
3
+ def initialize(name:, options:, label:, selected_value: nil, placeholder: nil, optional: false)
4
+ @name = name
5
+ @options = options
6
+ @label = label
7
+ @selected_value = selected_value
8
+ @placeholder = placeholder
9
+ @optional = optional
10
+ end
11
+
12
+ def render
13
+ picker = StaticPicker.create(name: @name, options: @options, value: @selected_value)
14
+ picker.merge(label: @label, placeholder: @placeholder, optional: @optional)
15
+ end
16
+
17
+ def self.create(name:, options:, label:, selected_value: nil, placeholder: nil, optional: false)
18
+ new(name: name,
19
+ options: options,
20
+ label: label,
21
+ selected_value: selected_value,
22
+ placeholder: placeholder,
23
+ optional: optional).render
24
+ end
25
+ end
26
+ end
@@ -0,0 +1,26 @@
1
+ module SlackWidgets
2
+ class Dialog::DialogTextBox
3
+ def initialize(name:, label:, placeholder: nil, value: nil, optional: false)
4
+ @name = name
5
+ @label = label
6
+ @placeholder = placeholder
7
+ @value = value
8
+ @optional = optional
9
+ end
10
+
11
+ def render
12
+ {
13
+ label: @label,
14
+ name: @name,
15
+ type: 'text',
16
+ placeholder: @placeholder,
17
+ value: @value,
18
+ optional: @optional
19
+ }
20
+ end
21
+
22
+ def self.create(name:, label:, placeholder: nil, value: nil, optional: false)
23
+ new(name: name, label: label, placeholder: placeholder, value: value, optional: optional).render
24
+ end
25
+ end
26
+ end
@@ -1,5 +1,4 @@
1
1
  module SlackWidgets
2
- # todo: should this be abstract?
3
2
  class Picker
4
3
  def initialize(name:, text: nil)
5
4
  @name = name
@@ -13,8 +13,9 @@ module SlackWidgets
13
13
  'selected_options': [@pre_selection],
14
14
  'value': @value)
15
15
  end
16
- end
17
- def self.create(name:, options:, text: nil, selected_index: nil, value: nil)
18
- new(name: name, options: options, text: text, selected_index: selected_index, value: value).render
16
+
17
+ def self.create(name:, options:, text: nil, selected_index: nil, value: nil)
18
+ new(name: name, options: options, text: text, selected_index: selected_index, value: value).render
19
+ end
19
20
  end
20
21
  end
data/lib/slack_widgets.rb CHANGED
@@ -4,7 +4,6 @@ require "slack_widgets/widgets/pickers/picker.rb"
4
4
 
5
5
  module SlackWidgets
6
6
  Dir[File.dirname(__FILE__) + "/slack_widgets/**/*.rb"].each do |file|
7
- p file
8
7
  require file
9
8
  end
10
9
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: slack_widgets
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.4
4
+ version: 0.3.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Benny Sitbon
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2017-10-13 00:00:00.000000000 Z
11
+ date: 2017-12-27 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -74,6 +74,9 @@ files:
74
74
  - lib/slack_widgets/widgets/buttons/button.rb
75
75
  - lib/slack_widgets/widgets/buttons/danger_button.rb
76
76
  - lib/slack_widgets/widgets/buttons/primary_button.rb
77
+ - lib/slack_widgets/widgets/dialogs/dialog.rb
78
+ - lib/slack_widgets/widgets/dialogs/dialog_picker.rb
79
+ - lib/slack_widgets/widgets/dialogs/dialog_textbox.rb
77
80
  - lib/slack_widgets/widgets/pickers/external_picker.rb
78
81
  - lib/slack_widgets/widgets/pickers/picker.rb
79
82
  - lib/slack_widgets/widgets/pickers/static_picker.rb