glib-web 0.5.41 → 0.5.46

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 667c7e9bef646b1a11ed8237b4fca8490dfd5cc6308dc6bbe01284402fbf605d
4
- data.tar.gz: 159bda20f1a5d19c1834d51669f7f8c990ad3ae34d766bec28e7b2ac6110b9cb
3
+ metadata.gz: c7ed6a0d03d3e4d8b1bdd0b9a7e309af80bb354d5b55c79aa3515cd14d2cfb8f
4
+ data.tar.gz: ed6cc91ab5a4e04a8913662202d384ab6f117a54f4e90f037627786cba49de27
5
5
  SHA512:
6
- metadata.gz: 2443bf21f9099aae0fddeed21226f02c466b4b123c5a7f69d9677a0a96c268f45b96ff7c91abebbd203ed88d71dc92ce817252083d8997cf0b8e09a1fd46ddae
7
- data.tar.gz: 05e3fca19eb376087e2444af5b8635110a0d14fc86a4c88210a4234018e90b228129ff6cd19ecb4792db6e060c5d3cf6dc3aa9777dcf3c996b4cf064ef21c96e
6
+ metadata.gz: 04d98e4e5d9be6ca1c887a640b9fe1cb8a610ea4659474bfe6fddda32e4d5209b7b1d2f297b6ff1d47b55290cd3df6a7d28cd3a8eea369d3619d730af1b9f3a5
7
+ data.tar.gz: 04ba97f0a0f606255f0458e42d03a08463da51aadf49cc578644212f8adc1241af1efd5fb9c44e6de468e25d64e69d19b7373aa49c9595e2fc1f8b428985d195
@@ -48,10 +48,15 @@ module Glib
48
48
  end
49
49
 
50
50
  def json_ui_action(json)
51
- @__json_ui_section ||= Page.new(json, self)
52
- @__json_ui_section.action_builder
51
+ @__json_ui_action ||= Page.new(json, self)
52
+ @__json_ui_action.action_builder
53
53
  end
54
54
 
55
+ # def json_ui_view(json)
56
+ # @__json_ui_view ||= Page.new(json, self)
57
+ # @__json_ui_view.view_builder
58
+ # end
59
+
55
60
  def json_ui_action_payload(&block)
56
61
  dataJson = Jbuilder.new
57
62
  block&.call Page.new(dataJson, self).action_builder
@@ -148,6 +148,7 @@ module Glib
148
148
  end
149
149
 
150
150
  class Hr < View
151
+ color :color
151
152
  end
152
153
 
153
154
  class Spacer < View
@@ -4,11 +4,11 @@ class Glib::JsonUi::ViewBuilder
4
4
  class AbstractField < View
5
5
  bool :readOnly
6
6
  hash :validation
7
- string :label
7
+ # string :label
8
8
 
9
- # def label(label)
10
- # @label = label
11
- # end
9
+ def label(label)
10
+ @label = label
11
+ end
12
12
 
13
13
  def label_args(label_args)
14
14
  @label_args = label_args
@@ -73,6 +73,9 @@ class Glib::JsonUi::ViewBuilder
73
73
 
74
74
  class Text < AbstractField
75
75
  int :maxLength
76
+ icon :leftIcon
77
+ string :leftText
78
+ string :rightText
76
79
  end
77
80
 
78
81
  class Number < Text
@@ -93,7 +93,7 @@ class Glib::JsonUi::ViewBuilder
93
93
  json.childViews do
94
94
  if @method != :get
95
95
  json.child! do
96
- json.view 'fields/hidden-v1'
96
+ json.view 'fields/hidden'
97
97
  json.name 'authenticity_token'
98
98
  json.value page.context.form_authenticity_token
99
99
  end
@@ -1,23 +1,22 @@
1
1
  json.title 'Actions'
2
2
 
3
- json_ui_page json do |page|
4
- render "#{@path_prefix}/nav_menu", json: json, page: page, top_nav: true
3
+ page = json_ui_page json
4
+ render "#{@path_prefix}/nav_menu", json: json, page: page, top_nav: true
5
5
 
6
- page.list sections: [
7
- ->(section) do
8
- render "#{@path_prefix}/actions/reload", section: section
9
- end, ->(section) do
10
- render "#{@path_prefix}/actions/dialogs", section: section
11
- end, ->(section) do
12
- render "#{@path_prefix}/actions/snackbars", section: section
13
- end, ->(section) do
14
- render "#{@path_prefix}/actions/sheets", section: section
15
- end, ->(section) do
16
- render "#{@path_prefix}/actions/windows", section: section
17
- end, ->(section) do
18
- render "#{@path_prefix}/actions/timeouts", section: section
19
- end, ->(section) do
20
- render "#{@path_prefix}/actions/http", section: section
21
- end
22
- ]
23
- end
6
+ page.list sections: [
7
+ ->(section) do
8
+ render "#{@path_prefix}/actions/reload", section: section
9
+ end, ->(section) do
10
+ render "#{@path_prefix}/actions/dialogs", section: section
11
+ end, ->(section) do
12
+ render "#{@path_prefix}/actions/snackbars", section: section
13
+ end, ->(section) do
14
+ render "#{@path_prefix}/actions/sheets", section: section
15
+ end, ->(section) do
16
+ render "#{@path_prefix}/actions/windows", section: section
17
+ end, ->(section) do
18
+ render "#{@path_prefix}/actions/timeouts", section: section
19
+ end, ->(section) do
20
+ render "#{@path_prefix}/actions/http", section: section
21
+ end
22
+ ]
@@ -1,22 +1,21 @@
1
1
  json.title 'Forms'
2
2
 
3
- json_ui_page json do |page|
4
- render "#{@path_prefix}/nav_menu", json: json, page: page
3
+ page = json_ui_page json
4
+ render "#{@path_prefix}/nav_menu", json: json, page: page
5
5
 
6
- page.form url: json_ui_garage_url(path: 'forms/basic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
7
- form.fields_text name: 'user[name]', width: 'matchParent', label: 'Name'
8
- form.fields_password name: 'user[password]', width: 'matchParent', label: 'Password'
6
+ page.form url: json_ui_garage_url(path: 'forms/basic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
7
+ form.fields_text name: 'user[name]', width: 'matchParent', label: 'Name'
8
+ form.fields_password name: 'user[password]', width: 'matchParent', label: 'Password'
9
9
 
10
- form.panels_split width: 'matchParent', content: ->(split) do
11
- split.left childViews: ->(left) do
12
- if params[:mode] == 'dialog'
13
- left.button styleClass: 'link', text: 'cancel', onClick: ->(action) { action.dialogs_close }
14
- end
15
- end
16
- split.right childViews: ->(right) do
17
- # right.button text: 'Submit', onClick: ->(action) { action.forms_submit }
18
- right.fields_submit text: 'Submit'
10
+ form.panels_split width: 'matchParent', content: ->(split) do
11
+ split.left childViews: ->(left) do
12
+ if params[:mode] == 'dialog'
13
+ left.button styleClass: 'link', text: 'cancel', onClick: ->(action) { action.dialogs_close }
19
14
  end
20
15
  end
16
+ split.right childViews: ->(right) do
17
+ # right.button text: 'Submit', onClick: ->(action) { action.forms_submit }
18
+ right.fields_submit text: 'Submit'
19
+ end
21
20
  end
22
21
  end
@@ -1,44 +1,43 @@
1
1
  json.title 'Forms'
2
2
 
3
- json_ui_page json do |page|
4
- render "#{@path_prefix}/nav_menu", json: json, page: page
5
-
6
- page.scroll childViews: ->(scroll) do
3
+ page = json_ui_page json
4
+ render "#{@path_prefix}/nav_menu", json: json, page: page
7
5
 
8
- scroll.panels_form url: json_ui_garage_url(path: 'forms/generic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
9
- form.spacer height: 20
10
- form.h2 text: 'Check Group'
11
- form.fields_checkGroup name: 'user[skills][]', uncheckValue: 1, childViews: ->(group) do
12
- form.fields_check value: 2, label: 'Game Development'
13
- form.fields_check value: 3, label: 'Web Development'
14
- form.fields_check value: 4, label: 'Mobile Development'
15
- end
6
+ page.scroll childViews: ->(scroll) do
7
+
8
+ scroll.panels_form url: json_ui_garage_url(path: 'forms/generic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
9
+ form.spacer height: 20
10
+ form.h2 text: 'Check Group'
11
+ form.fields_checkGroup name: 'user[skills][]', uncheckValue: 1, childViews: ->(group) do
12
+ form.fields_check value: 2, label: 'Game Development'
13
+ form.fields_check value: 3, label: 'Web Development'
14
+ form.fields_check value: 4, label: 'Mobile Development'
15
+ end
16
16
 
17
- form.spacer height: 20
18
- form.h2 text: 'Rating'
19
- form.spacer height: 6
20
- form.fields_radioGroup name: 'user[rating1][]', iconOfSelected: 'star', iconOfBeforeSelected: 'star', iconOfAfterSelected: 'star_border', childViews: ->(panel) do
21
- panel.panels_horizontal childViews: ->(panel) do
22
- panel.fields_radio value: 1
23
- panel.fields_radio value: 2
24
- panel.fields_radio value: 3
25
- panel.fields_radio value: 4
26
- panel.fields_radio value: 5
27
- end
17
+ form.spacer height: 20
18
+ form.h2 text: 'Rating'
19
+ form.spacer height: 6
20
+ form.fields_radioGroup name: 'user[rating1][]', iconOfSelected: 'star', iconOfBeforeSelected: 'star', iconOfAfterSelected: 'star_border', childViews: ->(panel) do
21
+ panel.panels_horizontal childViews: ->(panel) do
22
+ panel.fields_radio value: 1
23
+ panel.fields_radio value: 2
24
+ panel.fields_radio value: 3
25
+ panel.fields_radio value: 4
26
+ panel.fields_radio value: 5
28
27
  end
29
- form.fields_radioGroup name: 'user[rating2][]', iconOfSelected: 'star', iconOfBeforeSelected: 'star', iconOfAfterSelected: 'star_border', value: 1, childViews: ->(panel) do
30
- panel.panels_horizontal childViews: ->(panel) do
31
- panel.fields_radio value: 1
32
- panel.fields_radio value: 2
33
- panel.fields_radio value: 3
34
- panel.fields_radio value: 4
35
- panel.fields_radio value: 5
36
- end
28
+ end
29
+ form.fields_radioGroup name: 'user[rating2][]', iconOfSelected: 'star', iconOfBeforeSelected: 'star', iconOfAfterSelected: 'star_border', value: 1, childViews: ->(panel) do
30
+ panel.panels_horizontal childViews: ->(panel) do
31
+ panel.fields_radio value: 1
32
+ panel.fields_radio value: 2
33
+ panel.fields_radio value: 3
34
+ panel.fields_radio value: 4
35
+ panel.fields_radio value: 5
37
36
  end
38
-
39
- form.spacer height: 20
40
- form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
41
37
  end
42
-
38
+
39
+ form.spacer height: 20
40
+ form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
43
41
  end
42
+
44
43
  end
@@ -1,56 +1,39 @@
1
1
  json.title 'Forms'
2
2
 
3
- json_ui_page json do |page|
4
- render "#{@path_prefix}/nav_menu", json: json, page: page
3
+ page = json_ui_page json
4
+ render "#{@path_prefix}/nav_menu", json: json, page: page
5
5
 
6
- page.form url: json_ui_garage_url(path: 'forms/generic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
7
- form.h2 text: 'Dynamic Group'
8
- form.spacer height: 6
6
+ page.form url: json_ui_garage_url(path: 'forms/generic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
7
+ form.h2 text: 'Dynamic Group'
8
+ form.spacer height: 6
9
9
 
10
- # value = [
11
- # {
12
- # 'question': 'Punctuality',
13
- # 'type': 'rating'
14
- # },
15
- # {
16
- # 'question': 'Quality of work',
17
- # 'type': 'rating',
18
- # 'enabled': '1'
19
- # },
20
- # {
21
- # 'question': 'Satisfied?',
22
- # 'type': 'yes_no'
23
- # }
24
- # ]
25
-
26
- properties = [
27
- [
28
- { name: 'question', value: 'Punctuality' },
29
- { name: 'type', value: 'rating' },
30
- ],
31
- [
32
- { name: 'question', value: 'Quality of work' },
33
- { name: 'type', value: 'rating' },
34
- { name: 'enabled', value: '1', styleClasses: ['success'] },
35
- ],
36
- [
37
- { name: 'question', value: 'Satisfied?' },
38
- { name: 'type', value: 'yes_no' },
39
- ]
10
+ properties = [
11
+ [
12
+ { name: 'question', value: 'Punctuality' },
13
+ { name: 'type', value: 'rating' },
14
+ ],
15
+ [
16
+ { name: 'question', value: 'Quality of work' },
17
+ { name: 'type', value: 'rating' },
18
+ { name: 'enabled', value: '1', styleClasses: ['success'] },
19
+ ],
20
+ [
21
+ { name: 'question', value: 'Satisfied?' },
22
+ { name: 'type', value: 'yes_no' },
40
23
  ]
41
- form.fields_dynamicGroup width: 'matchParent', name: 'user[evaluation]', groupFieldProperties: properties, titlePrefix: 'Entry', content: ->(group) do
42
- group.template padding: { left: 32 }, childViews: ->(template) do
43
- template.spacer height: 10
44
- template.fields_text width: 'matchParent', name: 'question', label: 'Question', placeholder: 'Question'
45
- options = [ :rating, :yes_no ]
46
- template.fields_select width: 'matchParent', name: 'type', label: 'Answer Type', placeholder: 'Answer Type', options: options.map { |o| { text: o.to_s.humanize, value: o } }
47
- template.fields_check width: 'matchParent', name: 'enabled', label: 'Enable', checkValue: '1'
24
+ ]
25
+ form.fields_dynamicGroup width: 'matchParent', name: 'user[evaluation]', groupFieldProperties: properties, titlePrefix: 'Entry', content: ->(group) do
26
+ group.template padding: { left: 32 }, childViews: ->(template) do
27
+ template.spacer height: 10
28
+ template.fields_text width: 'matchParent', name: 'question', label: 'Question', placeholder: 'Question'
29
+ options = [ :rating, :yes_no ]
30
+ template.fields_select width: 'matchParent', name: 'type', label: 'Answer Type', placeholder: 'Answer Type', options: options.map { |o| { text: o.to_s.humanize, value: o } }
31
+ template.fields_check width: 'matchParent', name: 'enabled', label: 'Enable', checkValue: '1'
48
32
 
49
- template.spacer height: 14
50
- end
33
+ template.spacer height: 14
51
34
  end
52
-
53
- form.spacer height: 20
54
- form.fields_submit text: 'Submit'
55
35
  end
36
+
37
+ form.spacer height: 20
38
+ form.fields_submit text: 'Submit'
56
39
  end
@@ -1,25 +1,22 @@
1
1
  json.title 'Forms'
2
2
 
3
- json_ui_page json do |page|
4
- render "#{@path_prefix}/nav_menu", json: json, page: page
5
-
6
- page.form url: json_ui_garage_url(path: 'forms/generic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
7
- form.h2 text: 'Dynamic Select'
8
- form.spacer height: 6
3
+ page = json_ui_page json
4
+ render "#{@path_prefix}/nav_menu", json: json, page: page
9
5
 
10
- form.fields_dynamicSelect name: 'user[primary_language]', width: 'matchParent', label: 'Primary Language',
11
- # value: 'id3',
12
- selectedOptions: [ { value: 'id3', text: 'Item 3' } ],
13
- url: json_ui_garage_url(path: 'forms/dynamic_select_data')
6
+ page.form url: json_ui_garage_url(path: 'forms/generic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
7
+ form.h2 text: 'Dynamic Select'
8
+ form.spacer height: 6
14
9
 
15
- form.spacer height: 14
16
- form.fields_dynamicSelect name: 'user[preferred_languages][]', width: 'matchParent', label: 'Preferred Languages',
17
- # value: ['id3', 'id5'], multiple: true,
18
- selectedOptions: [ { value: 'id3', text: 'Item 3' }, { value: 'id5', text: 'Item 5' } ],
19
- url: json_ui_garage_url(path: 'forms/dynamic_select_data'),
20
- multiple: true
10
+ form.fields_dynamicSelect name: 'user[primary_language]', width: 'matchParent', label: 'Primary Language',
11
+ selectedOptions: [ { value: 'id3', text: 'Item 3' } ],
12
+ url: json_ui_garage_url(path: 'forms/dynamic_select_data')
21
13
 
22
- form.spacer height: 14
23
- form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
24
- end
14
+ form.spacer height: 14
15
+ form.fields_dynamicSelect name: 'user[preferred_languages][]', width: 'matchParent', label: 'Preferred Languages',
16
+ selectedOptions: [ { value: 'id3', text: 'Item 3' }, { value: 'id5', text: 'Item 5' } ],
17
+ url: json_ui_garage_url(path: 'forms/dynamic_select_data'),
18
+ multiple: true
19
+
20
+ form.spacer height: 14
21
+ form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
25
22
  end
@@ -6,60 +6,27 @@ options = {
6
6
  padding: { top: 12, left: 20, right: 20, bottom: 12 }
7
7
  }
8
8
 
9
- json_ui_page json do |page|
10
- render "#{@path_prefix}/nav_menu", json: json, page: page
11
-
12
- page.form options.merge(childViews: ->(form) do
13
- rules = { fileType: 'image/*', maxFileSize: 5000 }
14
- form.fields_file name: 'user[photo][]', width: 'matchParent', label: 'Landscape Photo', accepts: rules, directUploadUrl: rails_direct_uploads_url,
15
- value: 'eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBFQT09IiwiZXhwIjpudWxsLCJwdXIiOiJibG9iX2lkIn19--193dc0d939b9558fc4973fafbba91d989cbb04d4',
16
- fileUrl: 'https://imageserver-demo.herokuapp.com/image/itinerarybuilder-demo/o6CKzNt67PWnkPdUEnWMt7pr?h=100&w=100',
17
- fileTitle: '1 month ago',
18
- placeholderView: { type: 'image', width: 100, height: 75, url: 'https://www.atms.com.au/wp-content/uploads/2019/10/placeholder-1-1024x683.png?x93630' }
19
-
20
- rules = { fileType: 'image/*', maxFileSize: 1, fileTypeErrorText: 'Invalid!', maxFileSizeErrorText: 'Too big!' }
21
- form.fields_file name: 'user[photo][]', width: 'matchParent', label: 'Avatar', accepts: rules, directUploadUrl: rails_direct_uploads_url,
22
- placeholderView: { type: 'avatar', width: 100, height: 100, url: '' }
23
-
24
- rules = { fileType: 'pdf', maxFileSize: 5000 }
25
- form.fields_file name: 'user[pdf1][]', width: 'matchParent', label: 'PDF Document', accepts: rules, directUploadUrl: rails_direct_uploads_url,
26
- placeholderView: { type: 'image', width: 100, height: 100, url: '' }
27
-
28
- rules = { fileType: 'pdf', maxFileSize: 5000 }
29
- form.fields_file name: 'user[pdf2][]', width: 'matchParent', label: 'PDF Document', accepts: rules, directUploadUrl: rails_direct_uploads_url
30
-
31
- form.fields_submit text: 'Submit'
32
- # form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
33
- end)
34
- end
35
-
36
-
37
- # json_body_with_form json, nil, nil, options do
38
- # json.child! do
39
- # json.view 'fields/file-v1'
40
- # json.name 'user[photo]'
41
- # json.width 'matchParent'
42
- # json.label 'Photo'
43
-
44
- # json.value 'VALUE_OF_THE_PREVIOUS_IMAGE_WHICH_IS_USEFUL_WHEN_UPDATING_EXISTING_MODEL'
45
-
46
- # json.accepts "image/*"
47
- # # json.s3_bucket 'BUCKET_NAME'
48
- # # json.s3_path_prefix 'uploads/images'
49
- # json.s3_direct_upload_url rails_direct_uploads_path
50
-
51
- # # This is for security so we don't have to reveal key/secret in the json api
52
- # # json.s3_signature_url 'URL_TO_OUR_SERVER_TO_GET_GENERATED_SIGNATURE'
53
-
54
- # json.file_size_limit 5000 # 5 MB
55
- # json.file_size_limit_alert_text 'Too big!'
56
- # end
57
-
58
- # json.child! do
59
- # json.view 'button-v1'
60
- # json.text 'Submit'
61
- # json.onClick do
62
- # json.action 'forms/submit-v1'
63
- # end
64
- # end
65
- # end
9
+ page = json_ui_page json
10
+ render "#{@path_prefix}/nav_menu", json: json, page: page
11
+
12
+ page.form options.merge(childViews: ->(form) do
13
+ rules = { fileType: 'image/*', maxFileSize: 5000 }
14
+ form.fields_file name: 'user[photo][]', width: 'matchParent', label: 'Landscape Photo', accepts: rules, directUploadUrl: rails_direct_uploads_url,
15
+ value: 'eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBFQT09IiwiZXhwIjpudWxsLCJwdXIiOiJibG9iX2lkIn19--193dc0d939b9558fc4973fafbba91d989cbb04d4',
16
+ fileUrl: 'https://imageserver-demo.herokuapp.com/image/itinerarybuilder-demo/o6CKzNt67PWnkPdUEnWMt7pr?h=100&w=100',
17
+ fileTitle: '1 month ago',
18
+ placeholderView: { type: 'image', width: 100, height: 75, url: 'https://www.atms.com.au/wp-content/uploads/2019/10/placeholder-1-1024x683.png?x93630' }
19
+
20
+ rules = { fileType: 'image/*', maxFileSize: 1, fileTypeErrorText: 'Invalid!', maxFileSizeErrorText: 'Too big!' }
21
+ form.fields_file name: 'user[photo][]', width: 'matchParent', label: 'Avatar', accepts: rules, directUploadUrl: rails_direct_uploads_url,
22
+ placeholderView: { type: 'avatar', width: 100, height: 100, url: '' }
23
+
24
+ rules = { fileType: 'pdf', maxFileSize: 5000 }
25
+ form.fields_file name: 'user[pdf1][]', width: 'matchParent', label: 'PDF Document', accepts: rules, directUploadUrl: rails_direct_uploads_url,
26
+ placeholderView: { type: 'image', width: 100, height: 100, url: '' }
27
+
28
+ rules = { fileType: 'pdf', maxFileSize: 5000 }
29
+ form.fields_file name: 'user[pdf2][]', width: 'matchParent', label: 'PDF Document', accepts: rules, directUploadUrl: rails_direct_uploads_url
30
+
31
+ form.fields_submit text: 'Submit'
32
+ end)
@@ -1,31 +1,19 @@
1
1
  json.title 'Forms'
2
2
 
3
- # footer = Jbuilder.new do |json|
4
- # json.padding(top: 12, left: 20, right: 80, bottom: 12)
5
- # json.backgroundColor '#b3bac2'
6
- # json.subviews do
7
- # json.child! do
8
- # json.view 'label-v1'
9
- # json.text 'Demonstrates the use Floating Action Button on a form with footer'
10
- # end
11
- # end
12
- # end
13
-
14
3
  options = {
15
4
  url: json_ui_garage_url(path: 'forms/generic_post'),
16
5
  method: 'post',
17
6
  padding: { top: 12, left: 20, right: 20, bottom: 12 }
18
7
  }
19
8
 
20
- json_ui_page json do |page|
21
- render "#{@path_prefix}/nav_menu", json: json, page: page
22
-
23
- page.form options.merge(childViews: ->(form) do
24
- form.label text: 'Demonstrates the use Floating Action Button on a form with footer'
25
- 30.times do |i|
26
- form.fields_text name: "user[field#{i}]", width: 'matchParent', label: "Field#{i}"
27
- end
28
- form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
29
- form.fab icon: 'send', onClick: ->(action) { action.forms_submit }
30
- end)
31
- end
9
+ page = json_ui_page json
10
+ render "#{@path_prefix}/nav_menu", json: json, page: page
11
+
12
+ page.form options.merge(childViews: ->(form) do
13
+ form.label text: 'Demonstrates the use Floating Action Button on a form with footer'
14
+ 30.times do |i|
15
+ form.fields_text name: "user[field#{i}]", width: 'matchParent', label: "Field#{i}"
16
+ end
17
+ form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
18
+ form.fab icon: 'send', onClick: ->(action) { action.forms_submit }
19
+ end)
@@ -1,22 +1,59 @@
1
1
  json.title 'Forms'
2
2
 
3
- json_ui_page json do |page|
4
- render "#{@path_prefix}/nav_menu", json: json, page: page
3
+ page = json_ui_page json
4
+ render "#{@path_prefix}/nav_menu", json: json, page: page
5
5
 
6
- page.form url: json_ui_garage_url(path: 'forms/generic_post'), method: 'post', padding: glib_json_padding_body, childViews: ->(form) do
7
- form.fields_email name: 'user[email]', width: 'matchParent', label: 'Email'
8
- form.fields_url name: 'user[url]', width: 'matchParent', label: 'URL'
9
- form.fields_number name: 'user[number]', width: 'matchParent', label: 'Number', validation: { required: { message: 'Required' } }
10
- form.fields_password name: 'user[password]', width: 'matchParent', label: 'Password', hint: 'Should contain at least 6 characters'
11
- form.fields_textarea name: 'user[textarea]', width: 'matchParent', label: 'Textarea with maxLength', maxLength: 50, validation: { required: { message: 'Required' } }
6
+ page.form \
7
+ url: json_ui_garage_url(path: 'forms/generic_post'),
8
+ method: 'post',
9
+ padding: glib_json_padding_body,
10
+ childViews: ->(form) do
11
+ form.fields_email \
12
+ name: 'user[email]',
13
+ width: 'matchParent',
14
+ label: 'Email'
15
+
16
+ form.fields_url \
17
+ name: 'user[url]',
18
+ width: 'matchParent',
19
+ label: 'URL'
20
+
21
+ form.fields_number \
22
+ name: 'user[number]',
23
+ width: 'matchParent',
24
+ label: 'Number',
25
+ validation: { required: { message: 'Required' } },
26
+ leftText: 'USD',
27
+ rightText: '.00'
28
+
29
+ form.fields_password \
30
+ name: 'user[password]',
31
+ width: 'matchParent',
32
+ label: 'Password',
33
+ hint: 'Should contain at least 6 characters',
34
+ leftIcon: 'lock'
35
+
36
+ form.fields_textarea \
37
+ name: 'user[textarea]',
38
+ width: 'matchParent',
39
+ label: 'Textarea with maxLength',
40
+ maxLength: 50,
41
+ validation: { required: { message: 'Required' } }
12
42
 
13
43
  options = ['male', 'female'].map { |i| { text: i.humanize, value: i } }
14
- form.fields_select name: 'user[gender]', width: 'matchParent', label: 'Gender', validation: { required: { message: 'Required' } }, options: options
44
+ form.fields_select \
45
+ name: 'user[gender]',
46
+ width: 'matchParent',
47
+ label: 'Gender',
48
+ validation: { required: { message: 'Required' } },
49
+ options: options
15
50
 
16
51
  form.spacer height: 20
17
- form.fields_stripeToken name: 'user[stripe_token]', width: 'matchParent', publicKey: 'pk_test_TYooMQauvdEDq54NiTphI7jx'
52
+ form.fields_stripeToken \
53
+ name: 'user[stripe_token]',
54
+ width: 'matchParent',
55
+ publicKey: 'pk_test_TYooMQauvdEDq54NiTphI7jx'
18
56
 
19
57
  form.spacer height: 30
20
58
  form.fields_submit text: 'Submit'
21
59
  end
22
- end
@@ -24,12 +24,15 @@ json.pins do
24
24
  { lat: -42.734358, lng: 147.501315 },
25
25
  { lat: -42.735258, lng: 147.438 },
26
26
  { lat: -43.999792, lng: 170.463352 },
27
+ { lat: 49.003109, lng: 108.490479, size: 3500000 },
28
+ { lat: -6.611423, lng: 141.922091, size: 3700 },
27
29
  ];
28
30
 
29
31
  locations.each do |location|
30
32
  json.child! do
31
33
  json.latitude location[:lat]
32
34
  json.longitude location[:lng]
35
+ json.clusterSize location[:size]
33
36
  json.infoWindow do
34
37
  json.title "TEST #{rand(1000)}"
35
38
  end
@@ -1,6 +1,7 @@
1
1
 
2
- json.pins do
2
+ page = json_ui_page json
3
3
 
4
+ json.pins do
4
5
  latitude = params[:lat]&.to_f
5
6
  longitude = params[:long]&.to_f
6
7
 
@@ -37,7 +38,14 @@ json.pins do
37
38
  json.infoWindow do
38
39
  json.title 'You'
39
40
  json.subtitle 'Current location'
40
- json.subsubtitle "#{latitude}, #{longitude}"
41
+
42
+ json.body do
43
+ page.vertical_content padding: { top: 10 }, childViews: ->(body) do
44
+ body.button text: 'Info', onClick: ->(action) do
45
+ action.dialogs_alert message: "#{latitude}, #{longitude}"
46
+ end
47
+ end
48
+ end
41
49
  end
42
50
  end
43
51
  end
File without changes
@@ -1,41 +1,44 @@
1
1
  json.title 'Views'
2
2
 
3
- json_ui_page json do |page|
4
- render "#{@path_prefix}/nav_menu", json: json, page: page
5
-
6
- page.scroll padding: glib_json_padding_body, childViews: ->(scroll) do
7
- scroll.h1 text: 'Heading 1'
8
-
9
- scroll.spacer height: 10
10
- scroll.h2 text: 'Heading 2'
11
-
12
- scroll.spacer height: 10
13
- scroll.h3 text: 'Heading 3'
14
-
15
- scroll.spacer height: 10
16
- scroll.h4 text: 'Heading 4'
17
-
18
- scroll.spacer height: 10
19
- scroll.label text: 'Label'
20
-
21
- scroll.spacer height: 20
22
- scroll.hr width: 'matchParent'
23
-
24
- scroll.spacer height: 20
25
- scroll.h2 text: 'Paragraph'
26
- scroll.spacer height: 6
27
- scroll.p text: 'Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC,'\
28
- ' making it over 2000 years old. Richard McClintock, a Latin professor at Hampden-Sydney College in Virginia, looked up one of the more obscure Latin words,'\
29
- ' consectetur, from a Lorem Ipsum passage, and going through the cites of the word in classical literature, discovered the undoubtable source.'\
30
- ' Lorem Ipsum comes from sections 1.10.32 and 1.10.33 of "de Finibus Bonorum et Malorum" (The Extremes of Good and Evil) by Cicero, written in 45 BC.'\
31
- ' This book is a treatise on the theory of ethics, very popular during the Renaissance. The first line of Lorem Ipsum, "Lorem ipsum dolor sit amet..",'\
32
- ' comes from a line in section 1.10.32.' + "\n\n" +
33
- 'The standard chunk of Lorem Ipsum used since the 1500s is reproduced below for those interested. Sections 1.10.32 and 1.10.33 from "de Finibus Bonorum et Malorum"'\
34
- ' by Cicero are also reproduced in their exact original form, accompanied by English versions from the 1914 translation by H. Rackham.'
35
-
36
- scroll.spacer height: 20
37
- scroll.h2 text: 'Chip'
38
- scroll.spacer height: 6
39
- scroll.chip text: 'pending'
3
+ page = json_ui_page json
4
+ render "#{@path_prefix}/nav_menu", json: json, page: page
5
+
6
+ page.scroll padding: glib_json_padding_body, childViews: ->(scroll) do
7
+ scroll.h1 text: 'Heading 1'
8
+
9
+ scroll.spacer height: 10
10
+ scroll.h2 text: 'Heading 2'
11
+
12
+ scroll.spacer height: 10
13
+ scroll.h3 text: 'Heading 3'
14
+
15
+ scroll.spacer height: 10
16
+ scroll.h4 text: 'Heading 4'
17
+
18
+ scroll.spacer height: 10
19
+ scroll.label text: 'Label'
20
+
21
+ scroll.spacer height: 20
22
+ scroll.hr width: 'matchParent'
23
+
24
+ scroll.spacer height: 20
25
+ scroll.h2 text: 'Paragraph'
26
+ scroll.spacer height: 6
27
+ scroll.p text: 'Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC,'\
28
+ ' making it over 2000 years old. Richard McClintock, a Latin professor at Hampden-Sydney College in Virginia, looked up one of the more obscure Latin words,'\
29
+ ' consectetur, from a Lorem Ipsum passage, and going through the cites of the word in classical literature, discovered the undoubtable source.'\
30
+ ' Lorem Ipsum comes from sections 1.10.32 and 1.10.33 of "de Finibus Bonorum et Malorum" (The Extremes of Good and Evil) by Cicero, written in 45 BC.'\
31
+ ' This book is a treatise on the theory of ethics, very popular during the Renaissance. The first line of Lorem Ipsum, "Lorem ipsum dolor sit amet..",'\
32
+ ' comes from a line in section 1.10.32.' + "\n\n" +
33
+ 'The standard chunk of Lorem Ipsum used since the 1500s is reproduced below for those interested. Sections 1.10.32 and 1.10.33 from "de Finibus Bonorum et Malorum"'\
34
+ ' by Cicero are also reproduced in their exact original form, accompanied by English versions from the 1914 translation by H. Rackham.'
35
+
36
+ scroll.spacer height: 20
37
+ scroll.h2 text: 'Chip'
38
+ scroll.spacer height: 6
39
+ scroll.chip styleClass: 'success', text: 'pending'
40
+ scroll.spacer height: 6
41
+ scroll.chip text: 'Skills', onClick: ->(action) do
42
+ action.dialogs_alert message: 'Perform action'
40
43
  end
41
44
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: glib-web
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.41
4
+ version: 0.5.46
5
5
  platform: ruby
6
6
  authors:
7
7
  - ''