glib-web 0.5.43 → 0.5.48
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/app/helpers/glib/json_ui/action_builder.rb +8 -0
- data/app/helpers/glib/json_ui/list_builders.rb +1 -0
- data/app/helpers/glib/json_ui/page_helper.rb +11 -3
- data/app/helpers/glib/json_ui/view_builder/fields.rb +3 -0
- data/app/views/json_ui/garage/forms/dynamic_group.json.jbuilder +30 -47
- data/app/views/json_ui/garage/forms/dynamic_select.json.jbuilder +16 -19
- data/app/views/json_ui/garage/forms/file_upload.json.jbuilder +24 -57
- data/app/views/json_ui/garage/forms/floating_submit.json.jbuilder +11 -23
- data/app/views/json_ui/garage/forms/get_request.json.jbuilder +20 -21
- data/app/views/json_ui/garage/forms/index.json.jbuilder +83 -85
- data/app/views/json_ui/garage/forms/new_rich_text.json.jbuilder +28 -29
- data/app/views/json_ui/garage/forms/pickers.json.jbuilder +41 -43
- data/app/views/json_ui/garage/forms/text_validation.json.jbuilder +48 -11
- data/app/views/json_ui/garage/notifications/action_cable.json.jbuilder +26 -0
- data/app/views/json_ui/garage/notifications/index.json.jbuilder +5 -1
- data/app/views/json_ui/garage/views/texts.json.jbuilder +40 -37
- data/lib/glib/json_crawler/router.rb +2 -0
- data/lib/glib/test_helpers.rb +16 -4
- metadata +2 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: '096278d9b11151bcb169ba83f5c62c080471bb076f8ea3d34913e898a9537382'
|
4
|
+
data.tar.gz: bb831b31d185198292f251cbc3e9ab4536b1c4f3e3a28ceb32a5c7b76c25cba6
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: fcbb3bded93e840d4db717c74a78bd16537e405bdc2262343274604f9940d0b768256e6df5e01225d9f699d422693f5030e0156e5b9a596a4b685575355e8347
|
7
|
+
data.tar.gz: 99c46875985b061cea7e7932bb2a86c7b1d0f613c205ec15207cf212f1703df44eb6a03bffd81a5dfbd64e5b5a89b09d5f18ca830d48b2d95b6e8260bca065e0
|
@@ -95,10 +95,18 @@ module Glib
|
|
95
95
|
end
|
96
96
|
end
|
97
97
|
|
98
|
+
module Cables
|
99
|
+
class Push < Action
|
100
|
+
string :channel
|
101
|
+
string :event
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
98
105
|
module Timeouts
|
99
106
|
class Set < Action
|
100
107
|
int :interval # Milliseconds
|
101
108
|
action :onTimeout
|
109
|
+
bool :repeat
|
102
110
|
end
|
103
111
|
|
104
112
|
# FUTURE
|
@@ -201,9 +201,17 @@ module Glib
|
|
201
201
|
raise "Invalid properties: #{options.keys}" if options.size > 0
|
202
202
|
end
|
203
203
|
|
204
|
-
def onLoad(options = {})
|
205
|
-
|
206
|
-
|
204
|
+
# def onLoad(options = {})
|
205
|
+
# json.onLoad do
|
206
|
+
# yield @action_builder
|
207
|
+
# end
|
208
|
+
# end
|
209
|
+
|
210
|
+
def on(options = {})
|
211
|
+
if (on_load = options[:load])
|
212
|
+
json.onLoad do
|
213
|
+
on_load.call @action_builder
|
214
|
+
end
|
207
215
|
end
|
208
216
|
end
|
209
217
|
|
@@ -1,56 +1,39 @@
|
|
1
1
|
json.title 'Forms'
|
2
2
|
|
3
|
-
json_ui_page json
|
4
|
-
|
3
|
+
page = json_ui_page json
|
4
|
+
render "#{@path_prefix}/nav_menu", json: json, page: page
|
5
5
|
|
6
|
-
|
7
|
-
|
8
|
-
|
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
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
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
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
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
|
-
|
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
|
4
|
-
|
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
|
-
|
11
|
-
|
12
|
-
|
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
|
-
|
16
|
-
|
17
|
-
|
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
|
-
|
23
|
-
|
24
|
-
|
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
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
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
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
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)
|
@@ -2,27 +2,26 @@ json.title 'Forms'
|
|
2
2
|
|
3
3
|
data = params[:user] || {}
|
4
4
|
|
5
|
-
json_ui_page json
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
end
|
5
|
+
page = json_ui_page json
|
6
|
+
render "#{@path_prefix}/nav_menu", json: json, page: page
|
7
|
+
|
8
|
+
page.form url: json_ui_garage_url(path: 'forms/get_request'), method: 'get', padding: glib_json_padding_body, childViews: ->(form) do
|
9
|
+
# TODO: Potential improvement:
|
10
|
+
# Use `reload` behaviour instead of `open` (i.e. don't keep adding URL to history).
|
11
|
+
# Probably introduce a flag to panels_form so developer can enable/disable this behaviour.
|
12
|
+
form.h3 text: "Hello #{ data[:name] }"
|
13
|
+
form.spacer height: 6
|
14
|
+
form.label text: 'On the web, upon submit, URL needs to change on the browser'
|
15
|
+
form.spacer height: 10
|
16
|
+
form.fields_text name: 'user[name]', width: 'matchParent', label: 'Name'
|
17
|
+
|
18
|
+
# form.panels_split width: 'matchParent', rightViews: ->(split) do
|
19
|
+
# split.button text: 'Submit', onClick: ->(action) { action.forms_submit }
|
20
|
+
# end
|
21
|
+
|
22
|
+
form.panels_split width: 'matchParent', content: ->(split) do
|
23
|
+
split.right childViews: ->(right) do
|
24
|
+
right.button text: 'Submit', onClick: ->(action) { action.forms_submit }
|
26
25
|
end
|
27
26
|
end
|
28
27
|
end
|
@@ -1,110 +1,108 @@
|
|
1
1
|
json.title 'Forms'
|
2
2
|
|
3
|
-
json_ui_page json
|
4
|
-
|
3
|
+
page = json_ui_page json
|
4
|
+
render "#{@path_prefix}/nav_menu", json: json, page: page, top_nav: true
|
5
5
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
section.rows builder: ->(template) do
|
13
|
-
template.thumbnail title: 'Basic Logic', onClick: ->(action) do
|
14
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/basic')
|
15
|
-
end
|
16
|
-
template.thumbnail title: "Submission Flow (timestamp: #{DateTime.current.to_i})", onClick: ->(action) do
|
17
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/submission_flow')
|
18
|
-
end
|
19
|
-
template.thumbnail title: "Submission Indicator", onClick: ->(action) do
|
20
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/submission_indicator')
|
21
|
-
end
|
22
|
-
template.thumbnail title: 'GET Request', onClick: ->(action) do
|
23
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/get_request')
|
24
|
-
end
|
6
|
+
page.list sections: [
|
7
|
+
->(section) do
|
8
|
+
section.header padding: glib_json_padding_list, childViews: ->(header) do
|
9
|
+
header.h2 text: 'Submission Logics'
|
10
|
+
end
|
25
11
|
|
12
|
+
section.rows builder: ->(template) do
|
13
|
+
template.thumbnail title: 'Basic Logic', onClick: ->(action) do
|
14
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/basic')
|
26
15
|
end
|
27
|
-
|
28
|
-
|
29
|
-
|
16
|
+
template.thumbnail title: "Submission Flow (timestamp: #{DateTime.current.to_i})", onClick: ->(action) do
|
17
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/submission_flow')
|
18
|
+
end
|
19
|
+
template.thumbnail title: "Submission Indicator", onClick: ->(action) do
|
20
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/submission_indicator')
|
21
|
+
end
|
22
|
+
template.thumbnail title: 'GET Request', onClick: ->(action) do
|
23
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/get_request')
|
30
24
|
end
|
31
25
|
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/show_hide')
|
38
|
-
end
|
39
|
-
template.thumbnail title: 'Conditional Value', onClick: ->(action) do
|
40
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/conditional_value')
|
41
|
-
end
|
26
|
+
end
|
27
|
+
end, ->(section) do
|
28
|
+
section.header padding: glib_json_padding_list, childViews: ->(header) do
|
29
|
+
header.h2 text: 'Form Logics'
|
30
|
+
end
|
42
31
|
|
32
|
+
section.rows builder: ->(template) do
|
33
|
+
template.thumbnail title: 'Text Validation', onClick: ->(action) do
|
34
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/text_validation')
|
35
|
+
end
|
36
|
+
template.thumbnail title: 'Show/Hide', onClick: ->(action) do
|
37
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/show_hide')
|
43
38
|
end
|
44
|
-
|
45
|
-
|
46
|
-
header.h2 text: 'Form Fields'
|
39
|
+
template.thumbnail title: 'Conditional Value', onClick: ->(action) do
|
40
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/conditional_value')
|
47
41
|
end
|
48
42
|
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/selects')
|
55
|
-
end
|
56
|
-
template.thumbnail title: 'File Upload', onClick: ->(action) do
|
57
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/file_upload')
|
58
|
-
end
|
59
|
-
template.thumbnail title: 'Floating Submit', onClick: ->(action) do
|
60
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/floating_submit')
|
61
|
-
end
|
43
|
+
end
|
44
|
+
end, ->(section) do
|
45
|
+
section.header padding: glib_json_padding_list, childViews: ->(header) do
|
46
|
+
header.h2 text: 'Form Fields'
|
47
|
+
end
|
62
48
|
|
49
|
+
section.rows builder: ->(template) do
|
50
|
+
template.thumbnail title: 'Pickers', onClick: ->(action) do
|
51
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/pickers')
|
63
52
|
end
|
64
|
-
|
65
|
-
|
66
|
-
header.h2 text: 'Styling'
|
53
|
+
template.thumbnail title: 'Select Fields', onClick: ->(action) do
|
54
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/selects')
|
67
55
|
end
|
68
|
-
|
69
|
-
|
70
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/styled_boxes')
|
71
|
-
end
|
56
|
+
template.thumbnail title: 'File Upload', onClick: ->(action) do
|
57
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/file_upload')
|
72
58
|
end
|
73
|
-
|
74
|
-
|
75
|
-
header.h2 text: 'Web Only'
|
59
|
+
template.thumbnail title: 'Floating Submit', onClick: ->(action) do
|
60
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/floating_submit')
|
76
61
|
end
|
77
62
|
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
63
|
+
end
|
64
|
+
end, ->(section) do
|
65
|
+
section.header padding: glib_json_padding_list, childViews: ->(header) do
|
66
|
+
header.h2 text: 'Styling'
|
67
|
+
end
|
68
|
+
section.rows builder: ->(template) do
|
69
|
+
template.thumbnail title: 'Text Boxes', onClick: ->(action) do
|
70
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/styled_boxes')
|
82
71
|
end
|
72
|
+
end
|
73
|
+
end, ->(section) do
|
74
|
+
section.header padding: glib_json_padding_list, childViews: ->(header) do
|
75
|
+
header.h2 text: 'Web Only'
|
76
|
+
end
|
83
77
|
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
end
|
88
|
-
|
78
|
+
section.rows builder: ->(template) do
|
79
|
+
template.thumbnail title: 'Rich Text Editor', onClick: ->(action) do
|
80
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/rich_text')
|
89
81
|
end
|
90
|
-
end
|
91
|
-
|
92
|
-
|
82
|
+
end
|
83
|
+
|
84
|
+
section.rows builder: ->(template) do
|
85
|
+
template.thumbnail title: 'New Rich Text Editor', onClick: ->(action) do
|
86
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/new_rich_text')
|
93
87
|
end
|
94
88
|
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/dynamic_select')
|
101
|
-
end
|
102
|
-
template.thumbnail title: 'Checkboxes', onClick: ->(action) do
|
103
|
-
action.windows_open url: json_ui_garage_url(path: 'forms/checkboxes')
|
104
|
-
end
|
89
|
+
end
|
90
|
+
end, ->(section) do
|
91
|
+
section.header padding: glib_json_padding_list, childViews: ->(header) do
|
92
|
+
header.h2 text: 'Experimental (not required yet)'
|
93
|
+
end
|
105
94
|
|
95
|
+
section.rows builder: ->(template) do
|
96
|
+
template.thumbnail title: 'Dynamic Group', onClick: ->(action) do
|
97
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/dynamic_group')
|
98
|
+
end
|
99
|
+
template.thumbnail title: 'Dynamic Select', onClick: ->(action) do
|
100
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/dynamic_select')
|
101
|
+
end
|
102
|
+
template.thumbnail title: 'Checkboxes', onClick: ->(action) do
|
103
|
+
action.windows_open url: json_ui_garage_url(path: 'forms/checkboxes')
|
106
104
|
end
|
107
|
-
end
|
108
|
-
]
|
109
105
|
|
110
|
-
end
|
106
|
+
end
|
107
|
+
end
|
108
|
+
]
|
@@ -1,40 +1,39 @@
|
|
1
1
|
json.title 'Forms'
|
2
2
|
|
3
|
-
json_ui_page json
|
4
|
-
|
3
|
+
page = json_ui_page json
|
4
|
+
render "#{@path_prefix}/nav_menu", json: json, page: page
|
5
5
|
|
6
|
-
|
7
|
-
|
6
|
+
page.form url: json_ui_garage_url(path: 'forms/basic_post'), method: 'post', padding: { top: 12, left: 20, right: 20, bottom: 12 }, childViews: ->(form) do
|
7
|
+
form.fields_text name: 'user[name]', width: 'matchParent', label: 'Name'
|
8
8
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
9
|
+
# images = [
|
10
|
+
# {
|
11
|
+
# value: "eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBFQT09IiwiZXhwIjpudWxsLCJwdXIiOiJibG9iX2lkIn19--193dc0d939b9558fc4973fafbba91d989cbb04d4",
|
12
|
+
# fileUrl: "https://imageserver-demo.herokuapp.com/image/itinerarybuilder-demo/o6CKzNt67PWnkPdUEnWMt7pr?h=100&w=100"
|
13
|
+
# }
|
14
|
+
# ]
|
15
|
+
# form.fields_richText name: 'user[bio]', width: 'matchParent', label: 'Content', images: images, value: '<p>Test {{image1}}</p>'
|
16
16
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
17
|
+
json.child! do
|
18
|
+
json.view 'fields/newRichText-v1'
|
19
|
+
json.width 'matchParent'
|
20
|
+
json.label 'Content'
|
21
|
+
json.name 'user[bio]'
|
22
|
+
json.value '<p>Test {{image1}}</p>'
|
23
23
|
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
json.imageUploader do
|
33
|
-
json.accepts(fileType: "image/*", maxFileSize: 5000)
|
34
|
-
json.directUploadUrl rails_direct_uploads_url
|
24
|
+
json.images do
|
25
|
+
json.child! do
|
26
|
+
json.value "eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBFQT09IiwiZXhwIjpudWxsLCJwdXIiOiJibG9iX2lkIn19--193dc0d939b9558fc4973fafbba91d989cbb04d4"
|
27
|
+
# json.fileTitle "hita i hanom hg.jpg"
|
28
|
+
json.fileUrl "https://imageserver-demo.herokuapp.com/image/itinerarybuilder-demo/o6CKzNt67PWnkPdUEnWMt7pr?h=100&w=100"
|
35
29
|
end
|
36
30
|
end
|
37
31
|
|
38
|
-
|
32
|
+
json.imageUploader do
|
33
|
+
json.accepts(fileType: "image/*", maxFileSize: 5000)
|
34
|
+
json.directUploadUrl rails_direct_uploads_url
|
35
|
+
end
|
39
36
|
end
|
37
|
+
|
38
|
+
form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
|
40
39
|
end
|
@@ -1,48 +1,46 @@
|
|
1
1
|
json.title 'Forms'
|
2
2
|
|
3
|
-
json_ui_page json
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
end
|
15
|
-
|
16
|
-
form.spacer height: 20
|
17
|
-
form.h2 text: 'Single Checkbox'
|
18
|
-
form.fields_check name: 'user[age_range]', value: '16+', checkValue: '16+', uncheckValue: '0-16', label: 'I am over 16 (has default value)'
|
19
|
-
form.fields_check name: 'user[employer]', checkValue: 1, label: 'I am an employer (no default value)'
|
20
|
-
form.fields_check name: 'user[enabled]', checkValue: true, label: 'Enable', styleClass: 'switch', value: 'true'
|
21
|
-
|
22
|
-
form.spacer height: 20
|
23
|
-
form.h2 text: 'Date/Time'
|
24
|
-
form.spacer height: 6
|
25
|
-
form.fields_date name: 'user[date]', width: 'matchParent', label: 'Date', min: '2010-01-01', max: '2012-01-01', value: '2010-02-01'
|
26
|
-
form.fields_datetime name: 'user[date_time]', width: 'matchParent', label: 'Date Time', min: '2018-06-09T00:00', max: '2018-06-17T00:00', value: '2018-06-15T19:30'
|
27
|
-
|
28
|
-
form.spacer height: 20
|
29
|
-
form.h2 text: 'Country'
|
30
|
-
form.spacer height: 6
|
31
|
-
region_field = { name: 'user[city]', label: 'City' }
|
32
|
-
form.fields_country name: 'user[country]', width: 'matchParent', label: 'Country', region: region_field
|
33
|
-
|
34
|
-
form.spacer height: 20
|
35
|
-
form.h2 text: 'Map'
|
36
|
-
form.spacer height: 6
|
37
|
-
form.fields_location name: 'user[address]', width: 'matchParent', label: 'Type an address', value: 'Sydney Harbour Bridge',
|
38
|
-
autocompleteOptions: { componentRestrictions: { country: 'au' }, types: ['(cities)'] },
|
39
|
-
latitudeField: { view: 'fields/text', name: 'user[latitude]', label: 'Lat', value: -33.8523063, readOnly: true },
|
40
|
-
longitudeField: { view: 'fields/text', name: 'user[longitude]', label: 'Long', value: 151.21078710000006, readOnly: true },
|
41
|
-
zoomField: { view: 'fields/text', name: 'user[zoom]', label: 'Zoom' }
|
42
|
-
|
43
|
-
form.spacer height: 20
|
44
|
-
form.fields_submit text: 'Submit'
|
45
|
-
|
3
|
+
page = json_ui_page json
|
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: 'Radio Group'
|
8
|
+
form.spacer height: 6
|
9
|
+
form.h4 text: 'Gender'
|
10
|
+
form.fields_radioGroup name: 'user[gender]', value: 'F', childViews: ->(group) do
|
11
|
+
group.fields_radio value: '', label: 'Unknown'
|
12
|
+
group.fields_radio value: 'M', label: 'Male'
|
13
|
+
group.fields_radio value: 'F', label: 'Female'
|
46
14
|
end
|
47
15
|
|
16
|
+
form.spacer height: 20
|
17
|
+
form.h2 text: 'Single Checkbox'
|
18
|
+
form.fields_check name: 'user[age_range]', value: '16+', checkValue: '16+', uncheckValue: '0-16', label: 'I am over 16 (has default value)'
|
19
|
+
form.fields_check name: 'user[employer]', checkValue: 1, label: 'I am an employer (no default value)'
|
20
|
+
form.fields_check name: 'user[enabled]', checkValue: true, label: 'Enable', styleClass: 'switch', value: 'true'
|
21
|
+
|
22
|
+
form.spacer height: 20
|
23
|
+
form.h2 text: 'Date/Time'
|
24
|
+
form.spacer height: 6
|
25
|
+
form.fields_date name: 'user[date]', width: 'matchParent', label: 'Date', min: '2010-01-01', max: '2012-01-01', value: '2010-02-01'
|
26
|
+
form.fields_datetime name: 'user[date_time]', width: 'matchParent', label: 'Date Time', min: '2018-06-09T00:00', max: '2018-06-17T00:00', value: '2018-06-15T19:30'
|
27
|
+
|
28
|
+
form.spacer height: 20
|
29
|
+
form.h2 text: 'Country'
|
30
|
+
form.spacer height: 6
|
31
|
+
region_field = { name: 'user[city]', label: 'City' }
|
32
|
+
form.fields_country name: 'user[country]', width: 'matchParent', label: 'Country', region: region_field
|
33
|
+
|
34
|
+
form.spacer height: 20
|
35
|
+
form.h2 text: 'Map'
|
36
|
+
form.spacer height: 6
|
37
|
+
form.fields_location name: 'user[address]', width: 'matchParent', label: 'Type an address', value: 'Sydney Harbour Bridge',
|
38
|
+
autocompleteOptions: { componentRestrictions: { country: 'au' }, types: ['(cities)'] },
|
39
|
+
latitudeField: { view: 'fields/text', name: 'user[latitude]', label: 'Lat', value: -33.8523063, readOnly: true },
|
40
|
+
longitudeField: { view: 'fields/text', name: 'user[longitude]', label: 'Long', value: 151.21078710000006, readOnly: true },
|
41
|
+
zoomField: { view: 'fields/text', name: 'user[zoom]', label: 'Zoom' }
|
42
|
+
|
43
|
+
form.spacer height: 20
|
44
|
+
form.fields_submit text: 'Submit'
|
45
|
+
|
48
46
|
end
|
@@ -1,22 +1,59 @@
|
|
1
1
|
json.title 'Forms'
|
2
2
|
|
3
|
-
json_ui_page json
|
4
|
-
|
3
|
+
page = json_ui_page json
|
4
|
+
render "#{@path_prefix}/nav_menu", json: json, page: page
|
5
5
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
form.
|
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
|
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
|
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
|
@@ -0,0 +1,26 @@
|
|
1
|
+
page = json_ui_page json
|
2
|
+
|
3
|
+
# Implement a page that shows how ActionCable works in json_ui
|
4
|
+
|
5
|
+
# 1. Example for list
|
6
|
+
# column.panels_list actionCable: socket_config, width: 'matchParent', firstSection: ->(section) do
|
7
|
+
# section.rows objects: @messages, builder: -> (row, message, index) do
|
8
|
+
# render 'conversations/message', row: row, message: message, user: current_user
|
9
|
+
# end
|
10
|
+
# end
|
11
|
+
|
12
|
+
# 2. Example for textarea
|
13
|
+
# - TODO: Put onKeyUp in Textarea class in app/helpers/glib/json_ui/view_builder/fields.rb
|
14
|
+
# - TODO: Implement onKeyUp in glib-web-npm
|
15
|
+
# - TODO: Implement cables_push in glib-web-npm
|
16
|
+
# form.fields_textarea prop: :content, width: 'matchParent', label: 'Message', onKeyUp: ->(action) do
|
17
|
+
# action.cables_push channel: 'message', event: 'typing'
|
18
|
+
# end
|
19
|
+
|
20
|
+
# 3. Example for online status
|
21
|
+
# - TODO: Implement "repeat: true" in glib-web-npm
|
22
|
+
# page.on load: ->(action) do
|
23
|
+
# action.timeouts_set interval: 10000, repeat: true, onTimeout: ->(subaction) do
|
24
|
+
# subaction.cables_push channel: 'message', event: 'online'
|
25
|
+
# end
|
26
|
+
# end
|
@@ -25,8 +25,12 @@ page.list firstSection: ->(section) do
|
|
25
25
|
end
|
26
26
|
end
|
27
27
|
|
28
|
-
template.thumbnail title: 'WebSocket Real-time Update', onClick: ->(action) do
|
28
|
+
template.thumbnail title: 'Phoenix WebSocket Real-time Update', onClick: ->(action) do
|
29
29
|
action.windows_open url: json_ui_garage_url(path: 'notifications/web_socket')
|
30
30
|
end
|
31
|
+
|
32
|
+
template.thumbnail title: 'ActionCable Real-time Update', onClick: ->(action) do
|
33
|
+
action.windows_open url: json_ui_garage_url(path: 'notifications/action_cable')
|
34
|
+
end
|
31
35
|
end
|
32
36
|
end
|
@@ -1,41 +1,44 @@
|
|
1
1
|
json.title 'Views'
|
2
2
|
|
3
|
-
json_ui_page json
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
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
|
data/lib/glib/test_helpers.rb
CHANGED
@@ -13,7 +13,10 @@ module Glib
|
|
13
13
|
|
14
14
|
def __log_dir
|
15
15
|
if @__log_dir.nil?
|
16
|
-
@__log_dir = File.expand_path(
|
16
|
+
@__log_dir = File.expand_path(
|
17
|
+
"#{Rails.root}/test/controllers/#{self.class.to_s.underscore}_results",
|
18
|
+
File.dirname(__FILE__)
|
19
|
+
)
|
17
20
|
unless File.directory?(@__log_dir)
|
18
21
|
FileUtils.mkdir_p(@__log_dir)
|
19
22
|
end
|
@@ -26,15 +29,24 @@ module Glib
|
|
26
29
|
end
|
27
30
|
|
28
31
|
def __log(json)
|
29
|
-
File.open("#{File.join(__log_dir, __log_file)}", 'w') do |f|
|
32
|
+
file = File.open("#{File.join(__log_dir, __log_file)}", 'w') do |f|
|
30
33
|
f << JSON.pretty_generate(JSON.parse(json))
|
31
34
|
end
|
35
|
+
file.close
|
32
36
|
json
|
33
37
|
end
|
34
38
|
|
35
39
|
def __get_previous_result_from_git
|
36
|
-
|
37
|
-
|
40
|
+
if __git_is_available?
|
41
|
+
`git checkout -- "#{File.join(__log_dir, __log_file)}" > /dev/null 2>&1`
|
42
|
+
end
|
43
|
+
if File.exist?(
|
44
|
+
File.join(__log_dir, __log_file)
|
45
|
+
)
|
46
|
+
File.read(File.join(__log_dir, __log_file))
|
47
|
+
else
|
48
|
+
"\{\}"
|
49
|
+
end
|
38
50
|
end
|
39
51
|
end
|
40
52
|
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.
|
4
|
+
version: 0.5.48
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- ''
|
@@ -157,6 +157,7 @@ files:
|
|
157
157
|
- app/views/json_ui/garage/lists/index.json.jbuilder
|
158
158
|
- app/views/json_ui/garage/lists/reordering.json.jbuilder
|
159
159
|
- app/views/json_ui/garage/lists/templating.json.jbuilder
|
160
|
+
- app/views/json_ui/garage/notifications/action_cable.json.jbuilder
|
160
161
|
- app/views/json_ui/garage/notifications/android_post.json.jbuilder
|
161
162
|
- app/views/json_ui/garage/notifications/index.json.jbuilder
|
162
163
|
- app/views/json_ui/garage/notifications/web_socket.json.jbuilder
|