glib-web 0.5.30 → 0.5.37
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/helpers/glib/enum_helper.rb +8 -0
- data/app/helpers/glib/json_ui/action_builder.rb +1 -0
- data/app/helpers/glib/json_ui/list_builders.rb +1 -0
- data/app/helpers/glib/json_ui/page_helper.rb +5 -5
- data/app/helpers/glib/json_ui/view_builder/fields.rb +13 -6
- data/app/models/glib/application_record.rb +18 -0
- data/app/views/json_ui/garage/forms/file_upload.json.jbuilder +11 -4
- data/app/views/json_ui/garage/forms/pickers.json.jbuilder +1 -0
- data/app/views/json_ui/garage/forms/styled_boxes.json.jbuilder +9 -8
- data/app/views/json_ui/garage/pages/nav_buttons.json.jbuilder +1 -1
- data/lib/glib/json_crawler/action_crawlers/windows_open.rb +1 -1
- data/lib/glib/json_crawler/router.rb +2 -1
- metadata +3 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7cb7c646f770095389bca3804f3d1ab86c2d2dc240cdb934ccef1a16b93253be
|
4
|
+
data.tar.gz: fa79aaa7267315df1f0c34be561049c8a75e7ed333ad1eb630041bc7d654d0ff
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3f42d123df1f2b643c0f5db79b6e6acf9bb46e3eec41a0b3575c438ff18ed21ba18b08e67d52ca8056f7f68b3b1079184f6b5e70b1c235bd6d40b56cb536548a
|
7
|
+
data.tar.gz: 177314114e31104840908492faf6a9042205e6586cfcefb8adc1e5004d465f56ecdbffa18d58b799335b2be19278a8fb6d8cfcbb7e04909988c3c4f8a3f941e0
|
@@ -90,11 +90,11 @@ module Glib
|
|
90
90
|
builder
|
91
91
|
end
|
92
92
|
|
93
|
-
def rightNavButtons
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
end
|
93
|
+
# def rightNavButtons
|
94
|
+
# json.rightNavButtons do
|
95
|
+
# yield @menu_builder
|
96
|
+
# end
|
97
|
+
# end
|
98
98
|
|
99
99
|
def template(template)
|
100
100
|
json.template template
|
@@ -2,6 +2,7 @@ class Glib::JsonUi::ViewBuilder
|
|
2
2
|
module Fields
|
3
3
|
|
4
4
|
class AbstractField < View
|
5
|
+
bool :readOnly
|
5
6
|
hash :validation
|
6
7
|
|
7
8
|
def label(label)
|
@@ -68,7 +69,6 @@ class Glib::JsonUi::ViewBuilder
|
|
68
69
|
|
69
70
|
class Text < AbstractField
|
70
71
|
int :maxLength
|
71
|
-
bool :readOnly
|
72
72
|
end
|
73
73
|
|
74
74
|
class Number < Text
|
@@ -130,7 +130,7 @@ class Glib::JsonUi::ViewBuilder
|
|
130
130
|
|
131
131
|
class Select < AbstractField
|
132
132
|
array :options
|
133
|
-
bool :readOnly
|
133
|
+
# bool :readOnly
|
134
134
|
bool :multiple, cache: true
|
135
135
|
# bool :manualEntry
|
136
136
|
hash :append
|
@@ -138,7 +138,7 @@ class Glib::JsonUi::ViewBuilder
|
|
138
138
|
|
139
139
|
class Autocomplete < AbstractField
|
140
140
|
array :options
|
141
|
-
bool :readOnly
|
141
|
+
# bool :readOnly
|
142
142
|
bool :multiple, cache: true
|
143
143
|
# bool :manualEntry
|
144
144
|
hash :append
|
@@ -164,11 +164,17 @@ class Glib::JsonUi::ViewBuilder
|
|
164
164
|
# views :groupTemplateViews
|
165
165
|
end
|
166
166
|
|
167
|
-
class RadioGroup <
|
168
|
-
string :name
|
169
|
-
string :value
|
167
|
+
class RadioGroup < AbstractField
|
168
|
+
# string :name
|
169
|
+
# string :value
|
170
170
|
views :childViews
|
171
171
|
|
172
|
+
# Override
|
173
|
+
def value(value)
|
174
|
+
# Convert to string to make sure the value matches with Radio#value
|
175
|
+
@value = value.to_s if value != Glib::Value::DEFAULT
|
176
|
+
end
|
177
|
+
|
172
178
|
string :iconOfBeforeSelected
|
173
179
|
string :iconOfSelected
|
174
180
|
string :iconOfAfterSelected
|
@@ -211,6 +217,7 @@ class Glib::JsonUi::ViewBuilder
|
|
211
217
|
hash :latitudeField
|
212
218
|
hash :longitudeField
|
213
219
|
hash :zoomField
|
220
|
+
hash :autocompleteOptions
|
214
221
|
end
|
215
222
|
|
216
223
|
class StripeToken < AbstractField
|
@@ -0,0 +1,18 @@
|
|
1
|
+
module Glib
|
2
|
+
class ApplicationRecord < ActiveRecord::Base
|
3
|
+
self.abstract_class = true
|
4
|
+
|
5
|
+
scope :created_asc, -> { order(created_at: :asc) }
|
6
|
+
scope :created_desc, -> { order(created_at: :desc) }
|
7
|
+
|
8
|
+
def glib_enum_humanize(enum_name)
|
9
|
+
self.class.glib_enum_humanize(enum_name, send(enum_name))
|
10
|
+
end
|
11
|
+
|
12
|
+
def self.glib_enum_humanize(enum_name, enum_value)
|
13
|
+
if enum_value
|
14
|
+
I18n.t("activerecord.attributes.#{model_name.i18n_key}.#{enum_name.to_s.pluralize}.#{enum_value}")
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
@@ -10,17 +10,24 @@ json_ui_page json do |page|
|
|
10
10
|
render "#{@path_prefix}/nav_menu", json: json, page: page
|
11
11
|
|
12
12
|
page.form options.merge(childViews: ->(form) do
|
13
|
-
|
14
|
-
|
15
|
-
form.fields_file name: 'user[photo][]', width: 'matchParent', label: 'Landscape Photo', accepts: rules1, directUploadUrl: rails_direct_uploads_url,
|
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,
|
16
15
|
value: 'eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBFQT09IiwiZXhwIjpudWxsLCJwdXIiOiJibG9iX2lkIn19--193dc0d939b9558fc4973fafbba91d989cbb04d4',
|
17
16
|
fileUrl: 'https://imageserver-demo.herokuapp.com/image/itinerarybuilder-demo/o6CKzNt67PWnkPdUEnWMt7pr?h=100&w=100',
|
18
17
|
fileTitle: '1 month ago',
|
19
18
|
placeholderView: { type: 'image', width: 100, height: 75, url: 'https://www.atms.com.au/wp-content/uploads/2019/10/placeholder-1-1024x683.png?x93630' }
|
20
19
|
|
21
|
-
|
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
22
|
placeholderView: { type: 'avatar', width: 100, height: 100, url: '' }
|
23
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
|
+
|
24
31
|
form.fields_submit text: 'Submit'
|
25
32
|
# form.button text: 'Submit', onClick: ->(action) { action.forms_submit }
|
26
33
|
end)
|
@@ -35,6 +35,7 @@ json_ui_page json do |page|
|
|
35
35
|
form.h2 text: 'Map'
|
36
36
|
form.spacer height: 6
|
37
37
|
form.fields_location name: 'user[address]', width: 'matchParent', label: 'Type an address', value: 'Sydney Harbour Bridge',
|
38
|
+
autocompleteOptions: { componentRestrictions: { country: 'au' }, types: ['(cities)'] },
|
38
39
|
latitudeField: { view: 'fields/text', name: 'user[latitude]', label: 'Lat', value: -33.8523063, readOnly: true },
|
39
40
|
longitudeField: { view: 'fields/text', name: 'user[longitude]', label: 'Long', value: 151.21078710000006, readOnly: true },
|
40
41
|
zoomField: { view: 'fields/text', name: 'user[zoom]', label: 'Zoom' }
|
@@ -12,21 +12,22 @@ json_ui_page json do |page|
|
|
12
12
|
form.spacer height: 14
|
13
13
|
form.fields_textarea name: 'user[bio]', width: 'matchParent', label: 'Bio', placeholder: 'Enter your bio', styleClasses: ['outlined']
|
14
14
|
|
15
|
+
# form.spacer height: 14
|
16
|
+
# form.fields_stripeToken name: 'user[stripe_token_outlined]', width: 'matchParent', publicKey: 'pk_test_TYooMQauvdEDq54NiTphI7jx', styleClass: 'outlined'
|
17
|
+
|
18
|
+
# form.spacer height: 14
|
19
|
+
# form.fields_stripeToken name: 'user[stripe_token_individual]', width: 'matchParent', publicKey: 'pk_test_TYooMQauvdEDq54NiTphI7jx', styleClass: 'individual'
|
20
|
+
|
15
21
|
form.spacer height: 14
|
16
|
-
form.
|
22
|
+
form.fields_creditCard name: 'user[stripe_token_outlined]', width: 'matchParent', publicKey: 'pk_test_TYooMQauvdEDq54NiTphI7jx', styleClass: 'outlined'
|
17
23
|
|
18
24
|
form.spacer height: 14
|
19
|
-
form.
|
25
|
+
form.fields_creditCard name: 'user[stripe_token_individual]', width: 'matchParent', publicKey: 'pk_test_TYooMQauvdEDq54NiTphI7jx', styleClass: 'individual'
|
20
26
|
|
21
27
|
form.spacer height: 14
|
22
28
|
form.panels_split width: 'matchParent', content: ->(split) do
|
23
|
-
# split.left childViews: ->(left) do
|
24
|
-
# if params[:mode] == 'dialog'
|
25
|
-
# left.button styleClass: 'link', text: 'cancel', onClick: ->(action) { action.dialogs_close }
|
26
|
-
# end
|
27
|
-
# end
|
28
29
|
split.right childViews: ->(right) do
|
29
|
-
right.
|
30
|
+
right.fields_submit text: 'Submit'
|
30
31
|
end
|
31
32
|
end
|
32
33
|
|
@@ -5,7 +5,7 @@ page = json_ui_page json
|
|
5
5
|
render "#{@path_prefix}/nav_menu", json: json, page: page
|
6
6
|
|
7
7
|
page.navBar backgroundColor: '#a8c4e3', color: '#ffffff', rightButtons: ->(menu) do
|
8
|
-
menu.button icon: 'search', onClick: ->(action) do
|
8
|
+
menu.button icon: 'search', text: 'Search', onClick: ->(action) do
|
9
9
|
action.dialogs_alert message: 'Perform some action'
|
10
10
|
end
|
11
11
|
menu.button icon: { name: 'star', badge: { text: '1', backgroundColor: '#ff0000' } }, onClick: ->(action) do
|
@@ -12,7 +12,7 @@ module Glib
|
|
12
12
|
crawl json['body']&.[]('childViews')
|
13
13
|
crawl json['footer']&.[]('childViews')
|
14
14
|
|
15
|
-
json['
|
15
|
+
json['rightButtons']&.each do |button|
|
16
16
|
if button['buttons'].present?
|
17
17
|
button['buttons'].each do |inner_button|
|
18
18
|
click inner_button
|
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.37
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- ''
|
@@ -77,6 +77,7 @@ files:
|
|
77
77
|
- app/helpers/glib/app_feature_support_helper.rb
|
78
78
|
- app/helpers/glib/dynamic_images_helper.rb
|
79
79
|
- app/helpers/glib/dynamic_texts_helper.rb
|
80
|
+
- app/helpers/glib/enum_helper.rb
|
80
81
|
- app/helpers/glib/forms_helper.rb
|
81
82
|
- app/helpers/glib/json_ui/abstract_builder.rb
|
82
83
|
- app/helpers/glib/json_ui/action_builder.rb
|
@@ -103,6 +104,7 @@ files:
|
|
103
104
|
- app/helpers/glib/urls_helper.rb
|
104
105
|
- app/models/glib/active_storage/attachment.rb
|
105
106
|
- app/models/glib/active_storage/blob.rb
|
107
|
+
- app/models/glib/application_record.rb
|
106
108
|
- app/models/glib/dynamic_text_record.rb
|
107
109
|
- app/models/glib/text.rb
|
108
110
|
- app/policies/glib/application_policy.rb
|