glib-web 3.13.0 → 3.14.0
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/appearance_channel.rb +28 -0
- data/app/channels/glib/channel/chat_channel.rb +16 -0
- data/app/controllers/concerns/glib/json/libs.rb +105 -9
- data/app/controllers/concerns/glib/json/new_dynamic_text.rb +0 -0
- data/app/controllers/concerns/glib/json/ui.rb +1 -1
- data/app/controllers/glib/home_controller.rb +20 -0
- data/app/helpers/glib/app_feature_support_helper.rb +0 -0
- data/app/helpers/glib/dynamic_texts_helper.rb +0 -0
- data/app/helpers/glib/json_ui/action_builder/dialogs.rb +1 -0
- data/app/helpers/glib/json_ui/action_builder/fields.rb +8 -0
- data/app/helpers/glib/json_ui/action_builder/sheets.rb +0 -0
- data/app/helpers/glib/json_ui/action_builder.rb +15 -0
- data/app/helpers/glib/json_ui/analytics_helper.rb +0 -0
- data/app/helpers/glib/json_ui/generic_builders.rb +0 -0
- data/app/helpers/glib/json_ui/page_helper.rb +21 -0
- data/app/helpers/glib/json_ui/table_builders.rb +0 -0
- data/app/models/glib/active_storage/attachment.rb +0 -0
- data/app/models/glib/active_storage/blob.rb +0 -0
- data/app/models/glib/dynamic_text_record.rb +0 -0
- data/app/models/glib/text.rb +0 -0
- data/app/validators/email_typo_validator.rb +0 -0
- data/app/validators/email_validator.rb +0 -0
- data/app/validators/url_validator.rb +0 -0
- data/app/views/json_ui/garage/actions/_dialogs.json.jbuilder +14 -0
- data/app/views/json_ui/garage/actions/_dialogs_show.json.jbuilder +4 -1
- data/app/views/json_ui/garage/actions/_sheets.json.jbuilder +0 -0
- data/app/views/json_ui/garage/actions/dialogs_oauth_post.json.jbuilder +0 -0
- data/app/views/json_ui/garage/empty.json.jbuilder +3 -0
- data/app/views/json_ui/garage/forms/dialogs_close.json.jbuilder +14 -0
- data/app/views/json_ui/garage/forms/dialogs_update.json.jbuilder +12 -0
- data/app/views/json_ui/garage/forms/dirty_prompt.json.jbuilder +0 -1
- data/app/views/json_ui/garage/forms/dynamic_select_data.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/generic_post.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/submission_flow.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/submission_flow_post.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/submission_indicator.json.jbuilder +0 -0
- data/app/views/json_ui/garage/forms/submission_indicator_post.json.jbuilder +0 -0
- data/app/views/json_ui/garage/home/blank.json.jbuilder +0 -0
- data/app/views/json_ui/garage/home/slow.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/autoload_all.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/autoload_as_needed.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/chat_ui.json.jbuilder +0 -0
- data/app/views/json_ui/garage/lists/fab.json.jbuilder +0 -0
- data/app/views/json_ui/garage/notifications/action_cable.json.jbuilder +54 -100
- data/app/views/json_ui/garage/notifications/web_socket.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/custom_style_class.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/full_width.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/full_width_height.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/index.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/layout.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/lifecycle_hooks.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/loading_indicator.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/nested_scroll.json.jbuilder +0 -0
- data/app/views/json_ui/garage/pages/redirect_onload.json.jbuilder +0 -0
- data/app/views/json_ui/garage/panels/_styled.json.jbuilder +0 -0
- data/app/views/json_ui/garage/panels/card.json.jbuilder +0 -0
- data/app/views/json_ui/garage/panels/custom.json.jbuilder +0 -0
- data/app/views/json_ui/garage/panels/outlined.json.jbuilder +0 -0
- data/app/views/json_ui/garage/services/dynamic_text.json.jbuilder +0 -0
- data/app/views/json_ui/garage/services/image.json.jbuilder +0 -0
- data/app/views/json_ui/garage/services/index.json.jbuilder +0 -0
- data/app/views/json_ui/garage/tables/_autoload_section.json.jbuilder +0 -0
- data/app/views/json_ui/garage/tables/autoload_all.json.jbuilder +0 -0
- data/app/views/json_ui/garage/tables/autoload_as_needed.json.jbuilder +0 -0
- data/app/views/json_ui/garage/tables/export_import.json.jbuilder +0 -0
- data/app/views/json_ui/garage/tables/index.json.jbuilder +0 -0
- data/app/views/json_ui/garage/views/calendar_data.json.jbuilder +0 -0
- data/app/views/json_ui/garage/views/links.json.jbuilder +0 -0
- data/app/views/json_ui/garage/views/map_data.json.jbuilder +0 -0
- data/app/views/json_ui/garage/views/multimedia.json.jbuilder +0 -0
- data/app/views/layouts/json_ui/no_custom.html.erb +5 -0
- data/app/views/layouts/json_ui/renderer.html.erb +0 -2
- data/config/routes.rb +1 -0
- data/lib/generators/glib/install_generator.rb +0 -0
- data/lib/generators/templates/20191017062519_create_texts.rb +0 -0
- data/lib/generators/templates/20191024063257_add_scope_to_texts.rb +0 -0
- data/lib/generators/templates/20191112095018_add_lang_to_texts.rb +0 -0
- data/lib/generators/templates/20191126071051_create_active_storage_tables.active_storage.rb +0 -0
- data/lib/generators/templates/database.yml +0 -0
- data/lib/generators/templates/dynamic_text.rb +0 -0
- data/lib/glib/crypt/utils.rb +0 -0
- data/lib/glib/crypt.rb +0 -0
- data/lib/glib/dynamic_text/config.rb +0 -0
- data/lib/glib/dynamic_text.rb +0 -0
- data/lib/glib/engine.rb +0 -0
- data/lib/glib/json_crawler/action_crawler.rb +0 -0
- data/lib/glib/json_crawler/action_crawlers/action_http.rb +0 -0
- data/lib/glib/json_crawler/action_crawlers/dialogs_alert.rb +0 -0
- data/lib/glib/json_crawler/action_crawlers/menu.rb +0 -0
- data/lib/glib/json_crawler/action_crawlers/nav_initiate.rb +3 -3
- data/lib/glib/json_crawler/action_crawlers/run_multiple.rb +0 -0
- data/lib/glib/json_crawler/action_crawlers/windows_open.rb +0 -0
- data/lib/glib/json_crawler/coverage.rb +0 -0
- data/lib/glib/json_crawler/http.rb +2 -3
- data/lib/glib/json_crawler.rb +0 -0
- data/lib/glib/mailer_tester.rb +0 -0
- data/lib/glib/value.rb +0 -0
- data/lib/glib/version.rb +0 -0
- data/lib/glib-web.rb +0 -0
- metadata +10 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 33411954512fada9329818d4e011f5cb70f9c528a034fd87b8737318af18e07d
|
4
|
+
data.tar.gz: 492020f2693abdd8ffc38334c771cbe550952044f3030f9221fe163c5c49b103
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 97d3edb87b4e25bb71318dea8dd8243a2f98be27f74ac612e135100bfb5b12317c2b39e763f4e1301c2e3c08736fa7411f91a5a37eea96e1148b0d9d0e1e9841
|
7
|
+
data.tar.gz: 032b11ef90b8b22768459248da39de1a16f6342940cd902974bc96dc7d5a7c11acd7797d599e14bf21b11979b4ed237c053f9d82855856f29a7453b4f6ae98c4
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module Glib
|
2
|
+
module Channel
|
3
|
+
class AppearanceChannel < ApplicationCable::Channel
|
4
|
+
def subscribed
|
5
|
+
stream_for "appearance_#{params[:room]}"
|
6
|
+
end
|
7
|
+
|
8
|
+
def status(data)
|
9
|
+
action = {
|
10
|
+
action: 'labels/set',
|
11
|
+
targetId: 'label-1',
|
12
|
+
text: data['text']
|
13
|
+
# onSet: {
|
14
|
+
# action: 'timeouts/set',
|
15
|
+
# interval: 1000,
|
16
|
+
# onTimeout: {
|
17
|
+
# action: 'labels/set',
|
18
|
+
# targetId: 'label-1',
|
19
|
+
# text: "Room ##{data['room'].upcase}"
|
20
|
+
# }
|
21
|
+
# }
|
22
|
+
}
|
23
|
+
|
24
|
+
broadcast_to("appearance_#{data['room']}", action)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
module Glib
|
2
|
+
module Channel
|
3
|
+
class ChatChannel < ApplicationCable::Channel
|
4
|
+
rescue_from StandardError, with: :report_error
|
5
|
+
|
6
|
+
def subscribed
|
7
|
+
stream_for "chat_#{params[:room]}"
|
8
|
+
end
|
9
|
+
|
10
|
+
private
|
11
|
+
def report_error(e)
|
12
|
+
# Rollbar.error(e)
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -6,6 +6,8 @@ module Glib::Json::Libs
|
|
6
6
|
|
7
7
|
helper_method :json_ui_app_bundle_id, :json_ui_app_build_version, :json_ui_app_device_os
|
8
8
|
helper_method :json_ui_app_is_android?, :json_ui_app_is_ios?, :json_ui_app_is_web?
|
9
|
+
helper_method :json_ui_redirect_back_or_to
|
10
|
+
|
9
11
|
end
|
10
12
|
|
11
13
|
def json_ui_app_bundle_id
|
@@ -58,7 +60,7 @@ module Glib::Json::Libs
|
|
58
60
|
JSON.parse(render_to_string(template, locals: args))
|
59
61
|
end
|
60
62
|
|
61
|
-
def
|
63
|
+
def glib_redirect_to(url)
|
62
64
|
respond_to do |format|
|
63
65
|
format.html do
|
64
66
|
redirect_to url
|
@@ -75,11 +77,30 @@ module Glib::Json::Libs
|
|
75
77
|
end
|
76
78
|
end
|
77
79
|
|
78
|
-
|
79
|
-
|
80
|
+
# The behaviour provided by this convenience method assumes that user is logged in.
|
81
|
+
# When accessing a forbidden page, redirects to `user_default_url` because we don't
|
82
|
+
# want the user to get confused in the scenario where after logging in,
|
83
|
+
# glib_redirect_back_or_to tries to open a page that the user doesn't have access of.
|
84
|
+
def glib_handle_403(user_default_url)
|
85
|
+
respond_to do |format|
|
86
|
+
format.html do
|
87
|
+
redirect_to user_default_url
|
88
|
+
end
|
89
|
+
format.json do
|
90
|
+
render json: if glib_json_dialog_mode?
|
91
|
+
{ onLoad: __glib_error_dialog('Access denied', "Make sure you're logged in with the correct account.") }
|
92
|
+
else
|
93
|
+
{
|
94
|
+
onResponse: {
|
95
|
+
action: 'windows/open', url: user_default_url
|
96
|
+
}
|
97
|
+
}
|
98
|
+
end, status: Rails.env.test? ? :forbidden : :ok
|
99
|
+
end
|
100
|
+
end
|
80
101
|
end
|
81
102
|
|
82
|
-
def
|
103
|
+
def glib_handle_404
|
83
104
|
raise ActionController::RoutingError.new('Not Found')
|
84
105
|
|
85
106
|
# if json_ui_activated?
|
@@ -89,6 +110,69 @@ module Glib::Json::Libs
|
|
89
110
|
# end
|
90
111
|
end
|
91
112
|
|
113
|
+
REDIRECT_BACK_KEY = :glib_return_to_url
|
114
|
+
|
115
|
+
def glib_handle_401(sign_in_url)
|
116
|
+
if !glib_json_dialog_mode? && request.get?
|
117
|
+
session[REDIRECT_BACK_KEY] = url_for(params.to_unsafe_h.merge(format: nil))
|
118
|
+
end
|
119
|
+
|
120
|
+
respond_to do |format|
|
121
|
+
format.html do
|
122
|
+
redirect_to sign_in_url
|
123
|
+
end
|
124
|
+
format.json do
|
125
|
+
render json: {
|
126
|
+
# Handle dialogs_open and windows_open
|
127
|
+
glib_json_dialog_mode? ? :onLoad : :onResponse => __glib_error_dialog(
|
128
|
+
'Your session has ended', 'Please refresh the page and re-login.')
|
129
|
+
}, status: Rails.env.test? ? :unauthorized : :ok
|
130
|
+
end
|
131
|
+
end
|
132
|
+
end
|
133
|
+
|
134
|
+
def __delete_redirect_back_url(url)
|
135
|
+
redirect_url = session.delete(REDIRECT_BACK_KEY) || url
|
136
|
+
end
|
137
|
+
|
138
|
+
def glib_redirect_back_or_to(url)
|
139
|
+
redirect_url = __delete_redirect_back_url(url)
|
140
|
+
glib_redirect_to redirect_url
|
141
|
+
end
|
142
|
+
|
143
|
+
def json_ui_redirect_back_or_to(url, json_action)
|
144
|
+
redirect_url = __delete_redirect_back_url(url)
|
145
|
+
json_action.windows_closeAll onClose: ->(subaction) do
|
146
|
+
subaction.windows_open url: redirect_url
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
def glib_json_dialog_mode?
|
151
|
+
params[:_dialog].present? # E.g. _dialog=v1
|
152
|
+
end
|
153
|
+
|
154
|
+
def __glib_error_dialog(title, message)
|
155
|
+
{
|
156
|
+
action: 'dialogs/show',
|
157
|
+
# Don't show another dialog, just use the current one since it's a new dialog anyway, which means
|
158
|
+
# that it wouldn't contain existing user data.
|
159
|
+
updateExisting: glib_json_dialog_mode?,
|
160
|
+
title: title,
|
161
|
+
body: {
|
162
|
+
childViews: [
|
163
|
+
{
|
164
|
+
"view": "label",
|
165
|
+
"text": message
|
166
|
+
},
|
167
|
+
],
|
168
|
+
"padding": {
|
169
|
+
"x": 20,
|
170
|
+
"y": 22,
|
171
|
+
},
|
172
|
+
}
|
173
|
+
}
|
174
|
+
end
|
175
|
+
|
92
176
|
def glib_json_handle_500(exception)
|
93
177
|
if json_ui_activated? && Rails.env.production?
|
94
178
|
Rollbar.error(exception, :use_exception_level_filters => true) if defined?(Rollbar)
|
@@ -129,7 +213,7 @@ module Glib::Json::Libs
|
|
129
213
|
after_action :__json_traversal_register_dynamic_text
|
130
214
|
end
|
131
215
|
|
132
|
-
def json_libs_skip_json_ui(options)
|
216
|
+
def json_libs_skip_json_ui(options = {})
|
133
217
|
prepend_before_action options do
|
134
218
|
params[:_skip_render] = 'true'
|
135
219
|
end
|
@@ -152,13 +236,25 @@ module Glib::Json::Libs
|
|
152
236
|
rescue_from ActionController::InvalidAuthenticityToken do |exception|
|
153
237
|
sign_out(:user)
|
154
238
|
|
239
|
+
# respond_to do |format|
|
240
|
+
# format.json do
|
241
|
+
# render json: {
|
242
|
+
# onResponse: {
|
243
|
+
# action: 'windows/open-v1',
|
244
|
+
# url: url
|
245
|
+
# }
|
246
|
+
# }
|
247
|
+
# end
|
248
|
+
# end
|
249
|
+
|
155
250
|
respond_to do |format|
|
251
|
+
format.html do
|
252
|
+
redirect_to sign_in_url
|
253
|
+
end
|
156
254
|
format.json do
|
157
255
|
render json: {
|
158
|
-
|
159
|
-
|
160
|
-
url: root_url
|
161
|
-
}
|
256
|
+
glib_json_dialog_mode? ? :onLoad : :onResponse => __glib_error_dialog(
|
257
|
+
'Your session has expired', 'Please refresh the page and retry.')
|
162
258
|
}
|
163
259
|
end
|
164
260
|
end
|
File without changes
|
@@ -81,7 +81,7 @@ module Glib::Json::Ui
|
|
81
81
|
|
82
82
|
private
|
83
83
|
def __json_ui_vue(hash, options)
|
84
|
-
renderer_path = options[:renderer_path]
|
84
|
+
renderer_path = params[:_skip_custom_render] == 'true' ? 'layouts/json_ui/no_custom' : options[:renderer_path]
|
85
85
|
@__json_ui_orig_page = response.body
|
86
86
|
response.body = render_to_string(
|
87
87
|
template: renderer_path,
|
@@ -1,5 +1,9 @@
|
|
1
1
|
module Glib
|
2
2
|
class HomeController < ApplicationController
|
3
|
+
prepend_before_action do
|
4
|
+
params[:_skip_custom_render] = 'true' if params[:custom_render] != 'true'
|
5
|
+
end
|
6
|
+
|
3
7
|
if try(:glib_auth_inited?)
|
4
8
|
skip_before_action :glib_load_resource
|
5
9
|
skip_before_action :glib_authorize_resource
|
@@ -35,6 +39,22 @@ module Glib
|
|
35
39
|
render path
|
36
40
|
end
|
37
41
|
|
42
|
+
def chat
|
43
|
+
chat_params = params[:chat]
|
44
|
+
|
45
|
+
payload = {
|
46
|
+
action: 'lists/append',
|
47
|
+
targetId: 'list-1',
|
48
|
+
row: {
|
49
|
+
template: 'thumbnail', title: chat_params[:user], subtitle: chat_params[:body]
|
50
|
+
}
|
51
|
+
}
|
52
|
+
|
53
|
+
Glib::Channel::ChatChannel.broadcast_to("chat_#{chat_params[:room]}", payload)
|
54
|
+
|
55
|
+
render template: 'json_ui/garage/empty'
|
56
|
+
end
|
57
|
+
|
38
58
|
def init_orders
|
39
59
|
@order_headings = {}
|
40
60
|
@orders = params[:orders] || []
|
File without changes
|
File without changes
|
File without changes
|
@@ -124,6 +124,21 @@ module Glib
|
|
124
124
|
end
|
125
125
|
end
|
126
126
|
|
127
|
+
module Labels
|
128
|
+
class Set < Action
|
129
|
+
string :targetId
|
130
|
+
string :text
|
131
|
+
action :onSet
|
132
|
+
end
|
133
|
+
end
|
134
|
+
|
135
|
+
module Lists
|
136
|
+
class Append < Action
|
137
|
+
string :targetId
|
138
|
+
hash :row
|
139
|
+
end
|
140
|
+
end
|
141
|
+
|
127
142
|
# FUTURE
|
128
143
|
module Data
|
129
144
|
class Save < Action
|
File without changes
|
File without changes
|
@@ -10,6 +10,15 @@ module Glib
|
|
10
10
|
)
|
11
11
|
end
|
12
12
|
|
13
|
+
def glib_chat_url(options = {})
|
14
|
+
Glib::Web::Engine.routes.url_helpers.chat_url(options.merge(
|
15
|
+
protocol: request.protocol,
|
16
|
+
host: request.host,
|
17
|
+
port: request.port,
|
18
|
+
_render: params[:_render], format: params[:format])
|
19
|
+
)
|
20
|
+
end
|
21
|
+
|
13
22
|
def json_ui_garage_current_url(options = {})
|
14
23
|
json_ui_garage_url(options.merge(path: params[:path]))
|
15
24
|
end
|
@@ -89,6 +98,18 @@ module Glib
|
|
89
98
|
# @generic_content_builder = GenericBuilders::Content.new(json, self, @view_builder)
|
90
99
|
end
|
91
100
|
|
101
|
+
def actionCable(options = {})
|
102
|
+
json.actionCable do
|
103
|
+
if (on_error = options[:onError])
|
104
|
+
json.onError do
|
105
|
+
on_error.call(@action_builder)
|
106
|
+
end
|
107
|
+
end
|
108
|
+
|
109
|
+
json.channels options[:channels]
|
110
|
+
end
|
111
|
+
end
|
112
|
+
|
92
113
|
def content_builder(panelNames)
|
93
114
|
# NOTE: Can potentially be cached
|
94
115
|
builder = GenericBuilders::Content.new(json, self, @view_builder)
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
data/app/models/glib/text.rb
CHANGED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
@@ -66,6 +66,20 @@ section.rows builder: ->(template) do
|
|
66
66
|
action.dialogs_open fullscreen: 'mobile', url: json_ui_garage_url(path: 'forms/basic', mode: 'dialog')
|
67
67
|
end
|
68
68
|
|
69
|
+
if !Rails.env.test? # Prevent test failure
|
70
|
+
template.thumbnail title: 'dialogs/open (page with error)', onClick: ->(action) do
|
71
|
+
action.dialogs_open url: json_ui_garage_url(path: 'forms/non_existent', mode: 'dialog')
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
template.thumbnail title: 'dialogs/open (page with dialogs/close)', onClick: ->(action) do
|
76
|
+
action.dialogs_open url: json_ui_garage_url(path: 'forms/dialogs_close', mode: 'dialog')
|
77
|
+
end
|
78
|
+
|
79
|
+
template.thumbnail title: 'dialogs/open (page with dialogs/show with updateExisting)', onClick: ->(action) do
|
80
|
+
action.dialogs_open url: json_ui_garage_url(path: 'forms/dialogs_update', mode: 'dialog')
|
81
|
+
end
|
82
|
+
|
69
83
|
template.thumbnail title: 'dialogs/oauth', onClick: ->(action) do
|
70
84
|
if respond_to?(:user_facebook_omniauth_authorize_url)
|
71
85
|
provider = {
|
@@ -5,7 +5,10 @@ markdown = '## Emphasis' + "\n" +
|
|
5
5
|
"\n" +
|
6
6
|
'~~Strikethrough~~' + "\n"
|
7
7
|
|
8
|
-
|
8
|
+
options = {
|
9
|
+
updateExisting: true
|
10
|
+
}
|
11
|
+
action.send "dialogs_#{dialog_mode}", **options, content: ->(dialog) do
|
9
12
|
dialog.body padding: glib_json_padding_body, childViews: ->(body) do
|
10
13
|
body.markdown text: markdown
|
11
14
|
|
File without changes
|
File without changes
|
@@ -0,0 +1,14 @@
|
|
1
|
+
json.title 'Forms'
|
2
|
+
|
3
|
+
page = json_ui_page json
|
4
|
+
render "#{@path_prefix}/nav_menu", json: json, page: page
|
5
|
+
|
6
|
+
page.scroll childViews: ->(scroll) do
|
7
|
+
scroll.label text: 'This content will be replaced'
|
8
|
+
end
|
9
|
+
|
10
|
+
page.on load: ->(action) do
|
11
|
+
action.dialogs_close onClose: ->(subaction) do
|
12
|
+
subaction.windows_open url: json_ui_garage_url(path: 'home/blank')
|
13
|
+
end
|
14
|
+
end
|
@@ -0,0 +1,12 @@
|
|
1
|
+
json.title 'Forms'
|
2
|
+
|
3
|
+
page = json_ui_page json
|
4
|
+
render "#{@path_prefix}/nav_menu", json: json, page: page
|
5
|
+
|
6
|
+
page.scroll childViews: ->(scroll) do
|
7
|
+
scroll.label text: 'This content will be replaced'
|
8
|
+
end
|
9
|
+
|
10
|
+
page.on load: ->(action) do
|
11
|
+
render 'json_ui/garage/actions/dialogs_show', json: json, action: action, dialog_mode: :show
|
12
|
+
end
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
@@ -1,114 +1,68 @@
|
|
1
|
-
|
1
|
+
room = params[:room]
|
2
2
|
page = json_ui_page json
|
3
3
|
|
4
|
-
|
5
|
-
|
6
|
-
first_user = User.first
|
7
|
-
second_user = User.offset(1).first
|
8
|
-
# Implement a page that shows how ActionCable works in json_ui
|
4
|
+
random_key = SecureRandom.hex(3)
|
5
|
+
user = "randomuser##{random_key}"
|
9
6
|
|
10
|
-
|
11
|
-
# column.panels_list actionCable: socket_config, width: 'matchParent', firstSection: ->(section) do
|
12
|
-
# section.rows objects: @messages, builder: -> (row, message, index) do
|
13
|
-
# render 'conversations/message', row: row, message: message, user: current_user
|
14
|
-
# end
|
15
|
-
# end
|
7
|
+
json.title "User: #{user}"
|
16
8
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
# end
|
33
|
-
|
34
|
-
page.on load: ->(action) do
|
35
|
-
action.timeouts_set interval: 1000, repeat: true, onTimeout: ->(subaction) do
|
36
|
-
subaction.cables_push channel: online_channel, event: 'online_status', payload: { status: true, user_id: first_user.id }
|
37
|
-
end
|
9
|
+
if room.present?
|
10
|
+
page.actionCable \
|
11
|
+
channels: [
|
12
|
+
{
|
13
|
+
name: 'Glib::Channel::AppearanceChannel',
|
14
|
+
options: { targetId: 'label-1', room: room }
|
15
|
+
},
|
16
|
+
{
|
17
|
+
name: 'Glib::Channel::ChatChannel',
|
18
|
+
options: { targetId: 'list-1', room: room }
|
19
|
+
}
|
20
|
+
],
|
21
|
+
onError: ->(action) do
|
22
|
+
action.labels_set targetId: 'label-1', text: "Room ##{room.upcase} (OFF)"
|
23
|
+
end
|
38
24
|
end
|
39
25
|
|
40
|
-
# 4. Example for typing status
|
41
|
-
|
42
|
-
# put on app/channels/is_typing_channel.rb
|
43
|
-
# class IsTypingChannel < Glib::Channel::IsTypingChannel
|
44
|
-
# self.channel_name = 'IsTypingChannel'
|
45
|
-
# end
|
46
|
-
|
47
26
|
page.scroll padding: glib_json_padding_body, childViews: ->(scroll) do
|
48
27
|
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
filterKey: second_user.id,
|
54
|
-
params: {
|
55
|
-
conversation: 2
|
56
|
-
}
|
57
|
-
}
|
58
|
-
left.label actionCable: online_socket_config, text: ' '
|
59
|
-
|
60
|
-
left.fields_textarea \
|
61
|
-
width: 440,
|
62
|
-
label: "Messages from #{first_user.full_name}",
|
63
|
-
onTypeStart: lambda { |action|
|
64
|
-
action.cables_push \
|
65
|
-
channel: typing_channel, event: 'typing',
|
66
|
-
payload: { status: true, user_id: first_user.id }
|
67
|
-
},
|
68
|
-
onTypeEnd: lambda { |action|
|
69
|
-
action.cables_push \
|
70
|
-
channel: typing_channel,
|
71
|
-
event: 'typing',
|
72
|
-
payload: { status: false, user_id: first_user.id }
|
73
|
-
}
|
74
|
-
left.spacer height: 10
|
28
|
+
if room.present?
|
29
|
+
scroll.panels_form url: glib_chat_url, width: 'matchParent', height: 'matchParent', method: 'POST', childViews: ->(form) do
|
30
|
+
form.fields_hidden name: 'chat[room]', value: room
|
31
|
+
form.fields_hidden name: 'chat[user]', value: user
|
75
32
|
|
76
|
-
|
77
|
-
channel: typing_channel,
|
78
|
-
filterKey: first_user.id,
|
79
|
-
params: {
|
80
|
-
conversation: 2
|
81
|
-
}
|
82
|
-
}
|
83
|
-
left.label actionCable: socket_config, text: ' '
|
84
|
-
end
|
33
|
+
form.p id: 'label-1', text: "Room ##{room.upcase}"
|
85
34
|
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
onTypeStart: lambda { |action|
|
92
|
-
action.cables_push \
|
93
|
-
channel: typing_channel, event: 'typing',
|
94
|
-
payload: { status: true, user_id: second_user.id }
|
95
|
-
},
|
96
|
-
onTypeEnd: lambda { |action|
|
97
|
-
action.cables_push \
|
98
|
-
channel: typing_channel,
|
99
|
-
event: 'typing',
|
100
|
-
payload: { status: false, user_id: second_user.id }
|
101
|
-
}
|
102
|
-
right.spacer height: 10
|
35
|
+
form.panels_list width: 'matchParent', height: 'matchParent', id: 'list-1', sections: [
|
36
|
+
->(section) do
|
37
|
+
section.rows builder: ->(template) do
|
38
|
+
template.thumbnail title: 'System', subtitle: 'Feel free to discuss anything here.'
|
39
|
+
end
|
103
40
|
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
41
|
+
section.footer childViews: ->(footer) do
|
42
|
+
form.fields_text \
|
43
|
+
name: 'chat[body]',
|
44
|
+
width: 'matchParent',
|
45
|
+
onTypeStart: ->(action) do
|
46
|
+
action.cables_push \
|
47
|
+
event: 'status',
|
48
|
+
channel: 'Glib::Channel::AppearanceChannel',
|
49
|
+
payload: { text: "#{user} is typing", room: room }
|
50
|
+
end,
|
51
|
+
onTypeEnd: ->(action) do
|
52
|
+
action.cables_push \
|
53
|
+
event: 'status',
|
54
|
+
channel: 'Glib::Channel::AppearanceChannel',
|
55
|
+
payload: { text: "Room ##{room.upcase}", room: room }
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
]
|
112
60
|
end
|
61
|
+
|
62
|
+
else
|
63
|
+
scroll.button text: 'Goto room', onClick: ->(action) { action.windows_open url: json_ui_garage_url(path: 'notifications/action_cable', room: random_key) }
|
64
|
+
scroll.spacer height: 8
|
65
|
+
scroll.label text: 'Or you can ask other dev for room (by copying the url)'
|
113
66
|
end
|
67
|
+
|
114
68
|
end
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
@@ -9,8 +9,6 @@
|
|
9
9
|
<%= csrf_meta_tags %>
|
10
10
|
|
11
11
|
<%= vite_javascript_tag 'vue_renderer', defer: true %>
|
12
|
-
<%#= javascript_include_tag 'vue_renderer_extras', defer: true %>
|
13
|
-
|
14
12
|
<%= vite_stylesheet_tag 'vue_renderer' %>
|
15
13
|
<%# TODO: Remove this, for dev only %>
|
16
14
|
<%# <script src="https://cdn.tailwindcss.com"></script> %>
|
data/config/routes.rb
CHANGED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
data/lib/glib/crypt/utils.rb
CHANGED
File without changes
|
data/lib/glib/crypt.rb
CHANGED
File without changes
|
File without changes
|
data/lib/glib/dynamic_text.rb
CHANGED
File without changes
|
data/lib/glib/engine.rb
CHANGED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
@@ -7,9 +7,8 @@ module Glib
|
|
7
7
|
|
8
8
|
VALID_RESPONSE_CODES = [
|
9
9
|
(200..299).to_a,
|
10
|
-
##
|
11
|
-
|
12
|
-
# 403, ## FORBIDDEN Should be used for logged-in but not allowed to access
|
10
|
+
401, ## UNAUTHORIZED Should be used for not-logged-in
|
11
|
+
403, ## FORBIDDEN Should be used for logged-in but not allowed to access
|
13
12
|
].flatten
|
14
13
|
|
15
14
|
def initialize(context, user, router)
|
data/lib/glib/json_crawler.rb
CHANGED
File without changes
|
data/lib/glib/mailer_tester.rb
CHANGED
File without changes
|
data/lib/glib/value.rb
CHANGED
File without changes
|
data/lib/glib/version.rb
CHANGED
File without changes
|
data/lib/glib-web.rb
CHANGED
File without changes
|
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: 3.
|
4
|
+
version: 3.14.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- ''
|
@@ -72,6 +72,8 @@ executables: []
|
|
72
72
|
extensions: []
|
73
73
|
extra_rdoc_files: []
|
74
74
|
files:
|
75
|
+
- app/channels/glib/channel/appearance_channel.rb
|
76
|
+
- app/channels/glib/channel/chat_channel.rb
|
75
77
|
- app/channels/glib/channel/is_typing_channel.rb
|
76
78
|
- app/channels/glib/channel/online_channel.rb
|
77
79
|
- app/controllers/concerns/glib/analytics/funnel.rb
|
@@ -95,6 +97,7 @@ files:
|
|
95
97
|
- app/helpers/glib/json_ui/action_builder/commands.rb
|
96
98
|
- app/helpers/glib/json_ui/action_builder/components.rb
|
97
99
|
- app/helpers/glib/json_ui/action_builder/dialogs.rb
|
100
|
+
- app/helpers/glib/json_ui/action_builder/fields.rb
|
98
101
|
- app/helpers/glib/json_ui/action_builder/http.rb
|
99
102
|
- app/helpers/glib/json_ui/action_builder/iap.rb
|
100
103
|
- app/helpers/glib/json_ui/action_builder/panels.rb
|
@@ -148,6 +151,7 @@ files:
|
|
148
151
|
- app/views/json_ui/garage/actions/dialogs_oauth_post.json.jbuilder
|
149
152
|
- app/views/json_ui/garage/actions/index.json.jbuilder
|
150
153
|
- app/views/json_ui/garage/actions/partial_update.json.jbuilder
|
154
|
+
- app/views/json_ui/garage/empty.json.jbuilder
|
151
155
|
- app/views/json_ui/garage/forms/_alert_post_data.json.jbuilder
|
152
156
|
- app/views/json_ui/garage/forms/_conditional_banner.json.jbuilder
|
153
157
|
- app/views/json_ui/garage/forms/_partial_update_execute.json.jbuilder
|
@@ -156,6 +160,8 @@ files:
|
|
156
160
|
- app/views/json_ui/garage/forms/basic_post.json.jbuilder
|
157
161
|
- app/views/json_ui/garage/forms/checkboxes.json.jbuilder
|
158
162
|
- app/views/json_ui/garage/forms/conditional_value.json.jbuilder
|
163
|
+
- app/views/json_ui/garage/forms/dialogs_close.json.jbuilder
|
164
|
+
- app/views/json_ui/garage/forms/dialogs_update.json.jbuilder
|
159
165
|
- app/views/json_ui/garage/forms/dirty_prompt.json.jbuilder
|
160
166
|
- app/views/json_ui/garage/forms/dynamic_group.json.jbuilder
|
161
167
|
- app/views/json_ui/garage/forms/dynamic_select.json.jbuilder
|
@@ -269,6 +275,7 @@ files:
|
|
269
275
|
- app/views/json_ui/garage/views/shareButton.json.jbuilder
|
270
276
|
- app/views/json_ui/garage/views/steppers.json.jbuilder
|
271
277
|
- app/views/json_ui/garage/views/texts.json.jbuilder
|
278
|
+
- app/views/layouts/json_ui/no_custom.html.erb
|
272
279
|
- app/views/layouts/json_ui/renderer.html.erb
|
273
280
|
- config/routes.rb
|
274
281
|
- lib/generators/glib/install_generator.rb
|
@@ -319,7 +326,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
319
326
|
- !ruby/object:Gem::Version
|
320
327
|
version: '0'
|
321
328
|
requirements: []
|
322
|
-
|
329
|
+
rubyforge_project:
|
330
|
+
rubygems_version: 2.7.6
|
323
331
|
signing_key:
|
324
332
|
specification_version: 4
|
325
333
|
summary: ''
|