glib-web 0.5.45 → 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: b863f20666907aa007728759d473d1e8dad478ba7efffcb66aa94fb898536a35
4
- data.tar.gz: 21e14417f6a72d74e58a8e5ee1ebce72d2a21c11c6e5ba4fb363b7a6820f4c0b
3
+ metadata.gz: c7ed6a0d03d3e4d8b1bdd0b9a7e309af80bb354d5b55c79aa3515cd14d2cfb8f
4
+ data.tar.gz: ed6cc91ab5a4e04a8913662202d384ab6f117a54f4e90f037627786cba49de27
5
5
  SHA512:
6
- metadata.gz: 15f888278858a1e6b8ebdc9944c6abcf07e4b0746dc91ffd3694be98552026a43a664e9da8c8fb63c45c8eb31f6506c487f40b98de5c92bca3679b341612ae8d
7
- data.tar.gz: 3e2bdb8dbfeddacccbe3269bfe9973bd65cb398faa25207d315d1970b951647a1854d415db4004fd6485d335186ca1286b30c2397c588ae5d0104447b0e8fe42
6
+ metadata.gz: 04d98e4e5d9be6ca1c887a640b9fe1cb8a610ea4659474bfe6fddda32e4d5209b7b1d2f297b6ff1d47b55290cd3df6a7d28cd3a8eea369d3619d730af1b9f3a5
7
+ data.tar.gz: 04ba97f0a0f606255f0458e42d03a08463da51aadf49cc578644212f8adc1241af1efd5fb9c44e6de468e25d64e69d19b7373aa49c9595e2fc1f8b428985d195
@@ -74,6 +74,8 @@ class Glib::JsonUi::ViewBuilder
74
74
  class Text < AbstractField
75
75
  int :maxLength
76
76
  icon :leftIcon
77
+ string :leftText
78
+ string :rightText
77
79
  end
78
80
 
79
81
  class Number < Text
@@ -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)
@@ -23,13 +23,15 @@ page.form \
23
23
  width: 'matchParent',
24
24
  label: 'Number',
25
25
  validation: { required: { message: 'Required' } },
26
- leftIcon: 'attach_money'
26
+ leftText: 'USD',
27
+ rightText: '.00'
27
28
 
28
29
  form.fields_password \
29
30
  name: 'user[password]',
30
31
  width: 'matchParent',
31
32
  label: 'Password',
32
- hint: 'Should contain at least 6 characters'
33
+ hint: 'Should contain at least 6 characters',
34
+ leftIcon: 'lock'
33
35
 
34
36
  form.fields_textarea \
35
37
  name: 'user[textarea]',
@@ -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.45
4
+ version: 0.5.46
5
5
  platform: ruby
6
6
  authors:
7
7
  - ''