glib-web 4.34.4 → 4.34.6
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/view_builder/fields.rb +0 -1
- data/app/views/json_ui/garage/actions/_snackbars.json.jbuilder +12 -8
- data/app/views/json_ui/garage/forms/file_upload.json.jbuilder +14 -1
- data/lib/glib/json_crawler/router.rb +22 -1
- data/lib/glib/snapshot.rb +4 -2
- data/lib/glib/test_helpers.rb +4 -3
- metadata +15 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e3ea9484c291ccc85316747488e53cd57e750f472fe9fc5b3f7b6db5c2edb71d
|
4
|
+
data.tar.gz: '08a75c965f23e1a5dad3befc50eb9cd702a13229177ddc4bc852ceb2c856d632'
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c649327fca633976e67d7239f37206c575628ab8f8c5ee601ec44606d69171b54e0abf9b62601a55a3985ac1777171eca7df4498766c247997636da515464418
|
7
|
+
data.tar.gz: 17404c938a6bedc945159760009d2549b94fd01b08122a4c1a686a6ce3e4a7fe4a5131d0beeeb0b257088e074e02e422629679739d4a2cb3bebd1f9a2b0e313b
|
@@ -21,15 +21,19 @@ section.rows builder: ->(template) do
|
|
21
21
|
# end
|
22
22
|
|
23
23
|
template.thumbnail title: 'snackbars/select', onClick: ->(action) do
|
24
|
-
action.snackbars_select
|
25
|
-
|
26
|
-
|
24
|
+
action.snackbars_select \
|
25
|
+
styleClass: 'vertical',
|
26
|
+
message: 'This is a select snackbar with a really really really really long text',
|
27
|
+
onClose: ->(saction) { saction.dialogs_alert message: 'Closed' },
|
28
|
+
buttons: ->(menu) do
|
29
|
+
menu.button text: 'Option1', onClick: ->(subaction) do
|
30
|
+
subaction.dialogs_alert message: 'Option 1'
|
31
|
+
end
|
32
|
+
menu.button text: 'Option2', onClick: ->(subaction) do
|
33
|
+
subaction.dialogs_alert message: 'Option 2'
|
34
|
+
end
|
35
|
+
menu.button text: 'Cancel'
|
27
36
|
end
|
28
|
-
menu.button text: 'Option2', onClick: ->(subaction) do
|
29
|
-
subaction.dialogs_alert message: 'Option 2'
|
30
|
-
end
|
31
|
-
menu.button text: 'Cancel'
|
32
|
-
end
|
33
37
|
end
|
34
38
|
|
35
39
|
template.thumbnail title: 'snackbars with styling', onClick: ->(action) do
|
@@ -17,10 +17,13 @@ page.form options.merge(childViews: ->(form) do
|
|
17
17
|
fileTitle: '1 month ago',
|
18
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
19
|
|
20
|
-
rules = { fileType: 'image', maxFileSize:
|
20
|
+
rules = { fileType: 'image', maxFileSize: 100, maxFileSizeErrorText: 'Too big!' }
|
21
21
|
form.fields_file name: 'user[photo][]', width: 'matchParent', label: 'Avatar', accepts: rules, directUploadUrl: glib_direct_uploads_url,
|
22
22
|
placeholderView: { type: 'avatar', width: 100, height: 100, url: '' }
|
23
23
|
|
24
|
+
form.fields_file name: 'user[photo1][]', width: 'matchParent', label: 'Avatar without directUploadUrl', accepts: rules,
|
25
|
+
placeholderView: { type: 'avatar', width: 100, height: 100, url: '' }
|
26
|
+
|
24
27
|
rules = { fileType: 'pdf', maxFileSize: 5000 }
|
25
28
|
form.fields_file name: 'user[pdf1][]', width: 'matchParent', label: 'PDF Document', accepts: rules, directUploadUrl: glib_direct_uploads_url,
|
26
29
|
placeholderView: { type: 'image', width: 100, height: 100, url: '' }
|
@@ -80,6 +83,16 @@ page.form options.merge(childViews: ->(form) do
|
|
80
83
|
}
|
81
84
|
end
|
82
85
|
|
86
|
+
form.spacer height: 16
|
87
|
+
form.label text: 'File upload without directUploadUrl'
|
88
|
+
form.spacer height: 8
|
89
|
+
form.fields_multiUpload \
|
90
|
+
name: 'user[multi3][]',
|
91
|
+
width: 360,
|
92
|
+
accepts: { fileType: 'image', maxFileSize: 100 },
|
93
|
+
uploadTitle: 'Files uploaded:',
|
94
|
+
onFinishUpload: ->(action) { action.forms_submit }
|
95
|
+
|
83
96
|
form.spacer height: 16
|
84
97
|
form.label text: 'Sign'
|
85
98
|
form.spacer height: 8
|
@@ -1,10 +1,12 @@
|
|
1
|
+
require 'damerau-levenshtein'
|
2
|
+
|
1
3
|
module Glib
|
2
4
|
module JsonCrawler
|
3
5
|
class Router
|
4
6
|
attr_reader :read_only_actions # deprecated
|
5
7
|
attr_reader :logger, :last_log, :deferred_actions
|
6
8
|
attr_reader :http_actions
|
7
|
-
attr_accessor :host
|
9
|
+
attr_accessor :host, :skip_similar_page
|
8
10
|
|
9
11
|
def log(action, url, response = nil)
|
10
12
|
@last_log = [
|
@@ -53,6 +55,7 @@ module Glib
|
|
53
55
|
@host ||= 'localhost:3000'
|
54
56
|
@page_specs = []
|
55
57
|
@page_urls = []
|
58
|
+
@skip_similar_page = false
|
56
59
|
end
|
57
60
|
|
58
61
|
def step(http, args)
|
@@ -85,6 +88,8 @@ module Glib
|
|
85
88
|
assert_target_ids_exist(params)
|
86
89
|
|
87
90
|
if action.present?
|
91
|
+
return if similar_page?(params)
|
92
|
+
|
88
93
|
@depth += 1
|
89
94
|
case action
|
90
95
|
when 'initiate_navigation'
|
@@ -205,6 +210,22 @@ module Glib
|
|
205
210
|
regex = Regexp.new("#{host}.+(?<!\.pdf)$")
|
206
211
|
regex.match(url)
|
207
212
|
end
|
213
|
+
|
214
|
+
private
|
215
|
+
def similar_page?(params)
|
216
|
+
return false if http_actions.blank? || params['url'].blank?
|
217
|
+
return false if !skip_similar_page
|
218
|
+
|
219
|
+
result = false
|
220
|
+
http_actions.each do |http_action|
|
221
|
+
next if http_action[1].blank?
|
222
|
+
distance = ::DamerauLevenshtein.distance(http_action[1], params['url'])
|
223
|
+
result = (distance <= 1) && (http_action[0] == params['action'])
|
224
|
+
|
225
|
+
break if result
|
226
|
+
end
|
227
|
+
result
|
228
|
+
end
|
208
229
|
end
|
209
230
|
end
|
210
231
|
end
|
data/lib/glib/snapshot.rb
CHANGED
@@ -1,6 +1,8 @@
|
|
1
1
|
require 'active_snapshot'
|
2
2
|
require 'hashdiff'
|
3
3
|
|
4
|
+
# To get all records of a model, you can use the following query:
|
5
|
+
# MyModel.joins(:snapshots).distinct
|
4
6
|
module Glib
|
5
7
|
module Snapshot
|
6
8
|
extend ActiveSupport::Concern
|
@@ -127,7 +129,7 @@ module Glib
|
|
127
129
|
ignore_keys = default_ignored_keys
|
128
130
|
|
129
131
|
if !watched_keys_for_snapshot.nil?
|
130
|
-
ignored_keys_for_snapshot = attributes.except(*watched_keys_for_snapshot).keys
|
132
|
+
ignored_keys_for_snapshot = attributes.except(*watched_keys_for_snapshot.map(&:to_s)).keys
|
131
133
|
ignore_keys = (default_ignored_keys + ignored_keys_for_snapshot.map(&:to_s)).uniq
|
132
134
|
end
|
133
135
|
|
@@ -154,7 +156,7 @@ module Glib
|
|
154
156
|
|
155
157
|
association_ignored_keys =
|
156
158
|
if !first_record_off_same_collection.try(:watched_keys_for_snapshot).nil?
|
157
|
-
assoc_ignore_keys = first_record_off_same_collection.attributes.except(*first_record_off_same_collection.watched_keys_for_snapshot).keys.map(&:to_s)
|
159
|
+
assoc_ignore_keys = first_record_off_same_collection.attributes.except(*first_record_off_same_collection.watched_keys_for_snapshot.map(&:to_s)).keys.map(&:to_s)
|
158
160
|
(default_ignored_keys + assoc_ignore_keys).uniq
|
159
161
|
else
|
160
162
|
default_ignored_keys
|
data/lib/glib/test_helpers.rb
CHANGED
@@ -7,10 +7,10 @@ module Glib
|
|
7
7
|
end
|
8
8
|
|
9
9
|
module ClassMethods
|
10
|
-
def define_crawler_test(user, crawled_at, dump_path
|
10
|
+
def define_crawler_test(user, crawled_at, dump_path: , skip_similar_page: false, &on_after_crawl)
|
11
11
|
test "crawl api for #{user[:email]} #{user[:device]} #{user[:version] || 'current'}" do
|
12
12
|
Timecop.freeze(crawled_at || user[:crawled_at]) do
|
13
|
-
router = crawl_json_pages(user, dump_actions: dump_path.present?, dump_path: dump_path)
|
13
|
+
router = crawl_json_pages(user, dump_actions: dump_path.present?, dump_path: dump_path, skip_similar_page: skip_similar_page)
|
14
14
|
on_after_crawl&.call(router)
|
15
15
|
end
|
16
16
|
|
@@ -36,10 +36,11 @@ module Glib
|
|
36
36
|
assert_equal JSON.parse(expected), JSON.parse(result), "Result mismatch! #{__git_is_available? ? `git diff #{__controller_log_dir}/#{__controller_log_file}` : ''}"
|
37
37
|
end
|
38
38
|
|
39
|
-
def crawl_json_pages(user, log_file: nil, dump_actions: false, dump_path: nil, &block)
|
39
|
+
def crawl_json_pages(user, log_file: nil, dump_actions: false, dump_path: nil, skip_similar_page: false, &block)
|
40
40
|
__execute_crawler(user, inspect_http: true) do |router, http|
|
41
41
|
path = user[:path] ? "#{user[:path]}?format=json" : '/users/me?format=json&redirect=default'
|
42
42
|
router.host = HOST
|
43
|
+
router.skip_similar_page = skip_similar_page
|
43
44
|
router.step(
|
44
45
|
http,
|
45
46
|
'onClick' => {
|
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: 4.34.
|
4
|
+
version: 4.34.6
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- ''
|
@@ -122,6 +122,20 @@ dependencies:
|
|
122
122
|
- - ">="
|
123
123
|
- !ruby/object:Gem::Version
|
124
124
|
version: '0'
|
125
|
+
- !ruby/object:Gem::Dependency
|
126
|
+
name: damerau-levenshtein
|
127
|
+
requirement: !ruby/object:Gem::Requirement
|
128
|
+
requirements:
|
129
|
+
- - ">="
|
130
|
+
- !ruby/object:Gem::Version
|
131
|
+
version: '0'
|
132
|
+
type: :runtime
|
133
|
+
prerelease: false
|
134
|
+
version_requirements: !ruby/object:Gem::Requirement
|
135
|
+
requirements:
|
136
|
+
- - ">="
|
137
|
+
- !ruby/object:Gem::Version
|
138
|
+
version: '0'
|
125
139
|
description:
|
126
140
|
email: ''
|
127
141
|
executables: []
|