glib-web 0.5.45 → 0.5.51
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/channels/glib/channel/is_typing_channel.rb +28 -0
- data/app/controllers/concerns/glib/json/traversal.rb +5 -0
- data/app/controllers/glib/home_controller.rb +0 -0
- data/app/helpers/glib/json_ui/abstract_builder.rb +0 -0
- data/app/helpers/glib/json_ui/action_builder.rb +9 -0
- data/app/helpers/glib/json_ui/list_builders.rb +6 -1
- data/app/helpers/glib/json_ui/page_helper.rb +11 -3
- data/app/helpers/glib/json_ui/response_helper.rb +0 -0
- data/app/helpers/glib/json_ui/view_builder.rb +1 -0
- data/app/helpers/glib/json_ui/view_builder/fields.rb +4 -0
- data/app/helpers/glib/json_ui/view_builder/panels.rb +0 -0
- data/app/views/json_ui/garage/actions/index.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/_alert_post_data.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/conditional_value.json.jbuilder +0 -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/selects.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/show_hide.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/styled_boxes.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/text_validation.json.jbuilder +4 -2
- data/app/views/json_ui/garage/home/index.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/_autoload_section.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/edit_actions.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/index.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/reordering.json.jbuilder +13 -3
- data/app/views/json_ui/garage/notifications/action_cable.json.jbuilder +97 -0
- data/app/views/json_ui/garage/notifications/android_post.json.jbuilder +0 -0
- data/app/views/json_ui/garage/notifications/index.json.jbuilder +5 -1
- data/app/views/json_ui/garage/views/maps.json.jbuilder +0 -0
- 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 +24 -9
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 54ec1ebfb9977b82473a2a4677d83e0bd82975dbd39a2a3a2ffd4bd901903fb8
|
4
|
+
data.tar.gz: 322cfff138b7fa5e99e25b48512d7c56e4426edd94ea9638fad0695f6b4f5f11
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1462c3983c1a0a344e39171f7a5e41d5d394ff13fb7fa4f0ad62f27ac07e6ef272fe487090a502361305542e406bbc3f22d4d2001e014e1f87a4ef5b4a9ae959
|
7
|
+
data.tar.gz: 4c337b87a009042358b5848e902d41f2b03229679acbb93ff482246d57fae3fc0855bebb3902204b8fad12b4c36ff78a9aec788ff50f5db97a3fa77780d15c7d
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module Glib
|
2
|
+
module Channel
|
3
|
+
class IsTypingChannel < ApplicationCable::Channel
|
4
|
+
class << self
|
5
|
+
attr_accessor :channel_name
|
6
|
+
end
|
7
|
+
|
8
|
+
def channel_name
|
9
|
+
self.class.channel_name
|
10
|
+
end
|
11
|
+
|
12
|
+
def subscribed
|
13
|
+
stream_from "#{self.class.channel_name}_#{params['conversation_id']}"
|
14
|
+
end
|
15
|
+
|
16
|
+
def typing(data)
|
17
|
+
ActionCable.server.broadcast \
|
18
|
+
"#{self.class.channel_name}_#{params['conversation_id']}",
|
19
|
+
action: {
|
20
|
+
action: 'component/set',
|
21
|
+
name: User.find(data['user_id']).full_name,
|
22
|
+
status: data['status'],
|
23
|
+
user_id: data['user_id']
|
24
|
+
}
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -73,6 +73,11 @@ module Glib::Json::Traversal
|
|
73
73
|
traverse_vertical_content view['center'], block
|
74
74
|
traverse_vertical_content view['right'], block
|
75
75
|
|
76
|
+
# List template
|
77
|
+
traverse_multiple view['editButtons'], block
|
78
|
+
traverse_multiple view['leftButtons'], block
|
79
|
+
traverse_multiple view['rightButtons'], block
|
80
|
+
|
76
81
|
# TODO: crawl header and footer
|
77
82
|
# Table/List
|
78
83
|
if (sections = view['sections']).is_a? Array
|
File without changes
|
File without changes
|
@@ -95,10 +95,19 @@ module Glib
|
|
95
95
|
end
|
96
96
|
end
|
97
97
|
|
98
|
+
module Cables
|
99
|
+
class Push < Action
|
100
|
+
string :channel
|
101
|
+
string :event
|
102
|
+
hash :payload
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
98
106
|
module Timeouts
|
99
107
|
class Set < Action
|
100
108
|
int :interval # Milliseconds
|
101
109
|
action :onTimeout
|
110
|
+
bool :repeat
|
102
111
|
end
|
103
112
|
|
104
113
|
# FUTURE
|
@@ -11,6 +11,7 @@ module Glib
|
|
11
11
|
menu :rightButtons
|
12
12
|
menu :editButtons
|
13
13
|
menu :chips
|
14
|
+
singleton_array :styleClass, :styleClasses
|
14
15
|
|
15
16
|
# def editButtons(block)
|
16
17
|
# json.editButtons do
|
@@ -37,7 +38,11 @@ module Glib
|
|
37
38
|
bool :avatar
|
38
39
|
action :onReorder
|
39
40
|
string :paramNameForFormData
|
40
|
-
string :
|
41
|
+
string :paramNameForNewAbsoluteIndex
|
42
|
+
string :paramNameForNewSectionIndex
|
43
|
+
string :paramNameForNewSectionedRowIndex
|
44
|
+
|
45
|
+
string :paramNameForNewIndex # Deprecated
|
41
46
|
|
42
47
|
# # NOTE: Experimental. Still deciding whether this needs to be a full blown panel or
|
43
48
|
# # an array of badges (with relevant properties, e.g. text, color, etc)
|
@@ -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
|
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
@@ -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
|