nexmo-oas-renderer 2.2.0 → 2.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/pull_request-review.yml +14 -0
- data/Gemfile.lock +2 -2
- data/Procfile +1 -0
- data/app.json +15 -0
- data/lib/nexmo/oas/renderer/app.rb +1 -0
- data/lib/nexmo/oas/renderer/presenters/content_switcher.rb +47 -0
- data/lib/nexmo/oas/renderer/presenters/response_tabs.rb +2 -1
- data/lib/nexmo/oas/renderer/public/assets/javascripts/nexmo-oas-renderer.js +8 -0
- data/lib/nexmo/oas/renderer/public/assets/javascripts/volta.dropdown.js +145 -0
- data/lib/nexmo/oas/renderer/version.rb +1 -1
- data/lib/nexmo/oas/renderer/views/layouts/_javascripts.erb +2 -1
- data/lib/nexmo/oas/renderer/views/open_api/_header.erb +14 -0
- data/lib/nexmo/oas/renderer/views/open_api/_parameter_groups.erb +3 -2
- data/lib/nexmo/oas/renderer/views/open_api/_response_tabs.erb +15 -17
- data/lib/nexmo/oas/renderer/views/open_api/_tabbed_parameters.erb +15 -35
- data/lib/nexmo/oas/renderer/views/open_api/content_switcher/_dropdown.erb +22 -0
- data/lib/nexmo/oas/renderer/views/open_api/content_switcher/_tabs.erb +18 -0
- data/nexmo-oas-renderer.gemspec +1 -1
- metadata +11 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e03a9fd43494edf725f3fa2ff814fdc7179aca5a0757137cee1062f9464ee158
|
4
|
+
data.tar.gz: 64b5fd5577bb7e1c7f0bb7b156e7f6eaf9360461d1e676eeec1adf237a56ed6a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c72918d4cc110e29cf09374336f14158fcf974beb435990abf7a0499aaa6293a6b315bdc4daca0700a6508eaf4938e62e3ac6021082e88ae96bc02b32b2002ab
|
7
|
+
data.tar.gz: c265eb36b5b81ceaf227c619518c7642b63f175dd84ff28f6184caab09ab37ebe787558aa8d72d9587d963b48af8ae9e74bc0a642fcb528923571b2fef49a094
|
@@ -0,0 +1,14 @@
|
|
1
|
+
name: Review App
|
2
|
+
on:
|
3
|
+
pull_request_target:
|
4
|
+
types: [opened, reopened, synchronize, labeled, closed]
|
5
|
+
jobs:
|
6
|
+
create-review-app:
|
7
|
+
runs-on: ubuntu-latest
|
8
|
+
steps:
|
9
|
+
- name: Create Review App
|
10
|
+
uses: mheap/github-action-pr-heroku-review-app@v1
|
11
|
+
env:
|
12
|
+
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
13
|
+
HEROKU_PIPELINE_ID: ${{ secrets.HEROKU_PIPELINE_ID }}
|
14
|
+
HEROKU_API_TOKEN: ${{ secrets.HEROKU_API_TOKEN }}
|
data/Gemfile.lock
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
nexmo-oas-renderer (2.
|
4
|
+
nexmo-oas-renderer (2.3.0)
|
5
5
|
activemodel (~> 6.0)
|
6
6
|
activesupport (~> 6.0)
|
7
7
|
banzai (~> 0.1.2)
|
@@ -109,7 +109,7 @@ GEM
|
|
109
109
|
hansi (~> 0.2.0)
|
110
110
|
mustermann (= 1.1.1)
|
111
111
|
neatjson (0.9)
|
112
|
-
nexmo_markdown_renderer (0.4.
|
112
|
+
nexmo_markdown_renderer (0.4.2)
|
113
113
|
activemodel (~> 6.0)
|
114
114
|
banzai (~> 0.1.2)
|
115
115
|
i18n (~> 1.7)
|
data/Procfile
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
web: bundle exec ./exe/nexmo-oas-renderer
|
data/app.json
ADDED
@@ -13,6 +13,7 @@ require_relative './presenters/open_api_specification'
|
|
13
13
|
require_relative './presenters/navigation'
|
14
14
|
require_relative './presenters/request_body_raw'
|
15
15
|
require_relative './presenters/response_tabs'
|
16
|
+
require_relative './presenters/content_switcher'
|
16
17
|
require_relative './helpers/render'
|
17
18
|
require_relative './helpers/navigation'
|
18
19
|
require_relative './helpers/summary'
|
@@ -0,0 +1,47 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Nexmo
|
4
|
+
module OAS
|
5
|
+
module Renderer
|
6
|
+
module Presenters
|
7
|
+
class ContentSwitcher
|
8
|
+
def initialize(format:, label:, theme_light:, force_type: nil)
|
9
|
+
@format = format
|
10
|
+
@panels = []
|
11
|
+
@label = label
|
12
|
+
@force_type = force_type
|
13
|
+
@theme_light = theme_light
|
14
|
+
end
|
15
|
+
|
16
|
+
def add_content(title:, content:, tab_id:, active:)
|
17
|
+
@panels.push({
|
18
|
+
'title' => title,
|
19
|
+
'content' => content,
|
20
|
+
'x-tab-id' => tab_id,
|
21
|
+
'active' => active,
|
22
|
+
})
|
23
|
+
end
|
24
|
+
|
25
|
+
def render
|
26
|
+
type = 'tabs'
|
27
|
+
type = 'dropdown' if @panels.length >= 8
|
28
|
+
|
29
|
+
type = @force_type if @force_type
|
30
|
+
|
31
|
+
[:"open_api/content_switcher/_#{type}", locals: {
|
32
|
+
panels: @panels,
|
33
|
+
format: @format,
|
34
|
+
label: @label,
|
35
|
+
switcher: self,
|
36
|
+
theme_light: @theme_light,
|
37
|
+
}]
|
38
|
+
end
|
39
|
+
|
40
|
+
def id
|
41
|
+
@id ||= "s-#{SecureRandom.hex}"
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
@@ -8,7 +8,7 @@ module Nexmo
|
|
8
8
|
module Renderer
|
9
9
|
module Presenters
|
10
10
|
class ResponseTabs
|
11
|
-
attr_reader :format
|
11
|
+
attr_reader :format, :switcher
|
12
12
|
|
13
13
|
def initialize(format, response, content, endpoint, theme_light: nil)
|
14
14
|
@format = format
|
@@ -16,6 +16,7 @@ module Nexmo
|
|
16
16
|
@content = content
|
17
17
|
@endpoint = endpoint
|
18
18
|
@theme_light = theme_light
|
19
|
+
@switcher ||= @response.schema(@format)['x-switcher']
|
19
20
|
end
|
20
21
|
|
21
22
|
def tab_links
|
@@ -20,6 +20,14 @@ document.addEventListener("DOMContentLoaded", function() {
|
|
20
20
|
var matchingTabs = document.querySelectorAll('[data-tab-link="' + link + '"]');
|
21
21
|
Array.from(matchingTabs).forEach(function (element) {
|
22
22
|
element.dispatchEvent(new Event('toggle'));
|
23
|
+
|
24
|
+
// Switch anything that's in a dropdown
|
25
|
+
if (element.parentNode.className.indexOf("Vlt-dropdown__panel__content") !== -1) {
|
26
|
+
// This is *very* structure dependent, but also the most compatible way to handle it
|
27
|
+
var panel = element.parentNode.parentNode;
|
28
|
+
var titleNodes = Array.from(panel.previousSibling.previousSibling.firstChild.childNodes);
|
29
|
+
titleNodes[1].textContent = element.textContent;
|
30
|
+
}
|
23
31
|
});
|
24
32
|
});
|
25
33
|
});
|
@@ -0,0 +1,145 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright (c) 2001-present, Vonage.
|
3
|
+
*
|
4
|
+
* Dropdowns (requires core)
|
5
|
+
*/
|
6
|
+
|
7
|
+
'use strict';
|
8
|
+
|
9
|
+
Volta.dropdown = function () {
|
10
|
+
var _class = {
|
11
|
+
wrapper: 'Vlt-dropdown',
|
12
|
+
block: 'Vlt-dropdown__block',
|
13
|
+
btn: 'Vlt-dropdown__trigger',
|
14
|
+
btnLegacy: 'Vlt-dropdown__btn',
|
15
|
+
dismissed: 'Vlt-callout--dismissed',
|
16
|
+
expanded: 'Vlt-dropdown--expanded',
|
17
|
+
label: 'Vlt-dropdown__label',
|
18
|
+
link: 'Vlt-dropdown__link',
|
19
|
+
noCloseLink: 'Vlt-dropdown__link--noclose',
|
20
|
+
noCloseBlock: 'Vlt-dropdown__block--noclose',
|
21
|
+
panel: 'Vlt-dropdown__panel',
|
22
|
+
panelContent: 'Vlt-dropdown__panel__content',
|
23
|
+
selection: 'Vlt-dropdown__selection',
|
24
|
+
switch: 'Vlt-switch',
|
25
|
+
switchSlider: 'Vlt-switch__slider'
|
26
|
+
}
|
27
|
+
|
28
|
+
function Dropdown() {}
|
29
|
+
|
30
|
+
Dropdown.prototype = {
|
31
|
+
init: function(element, supressClickHandler) {
|
32
|
+
this.dropdown = element;
|
33
|
+
this.selection = this.dropdown.querySelector('.' + _class.selection);
|
34
|
+
this.isSelectionVisible = !!this.selection;
|
35
|
+
this.btn = this.dropdown.querySelector('.' + _class.btn) || this.dropdown.querySelector('.' + _class.btnLegacy);
|
36
|
+
this._suppress = supressClickHandler;
|
37
|
+
|
38
|
+
if(!this._suppress) {
|
39
|
+
this._addEventListener();
|
40
|
+
}
|
41
|
+
},
|
42
|
+
_addEventListener: function(){
|
43
|
+
var openHandler = this.open.bind(this);
|
44
|
+
this.dropdown.addEventListener('click', openHandler, { once: true })
|
45
|
+
},
|
46
|
+
close: function(text) {
|
47
|
+
if(text) {
|
48
|
+
this._setDropdownSelectionText(text);
|
49
|
+
}
|
50
|
+
this.dropdown.classList.remove(_class.expanded);
|
51
|
+
|
52
|
+
if(!this._suppress){
|
53
|
+
this._addEventListener();
|
54
|
+
}
|
55
|
+
|
56
|
+
},
|
57
|
+
_closeEventHandler: undefined,
|
58
|
+
_closeEvent: function(e) {
|
59
|
+
var targetIsPanel = Volta._hasClass(e.target, _class.panel);
|
60
|
+
var parentIsPanel = Volta._closest(e.target, '.' + _class.panelContent, _class.panel) !== null;
|
61
|
+
var parentLink = Volta._closest(e.target, '.' + _class.link, _class.wrapper);
|
62
|
+
var parentIsLink = parentLink && parentLink.length === 1;
|
63
|
+
var isSwitchSlider = Volta._hasClass(e.target, _class.switchSlider);
|
64
|
+
var isParentSwitch = Volta._closest(e.target,'.' + _class.switch, _class.link);
|
65
|
+
var isNoClose = Volta._hasClass(e.target, _class.noCloseLink) || Volta._hasClass(e.target, _class.noCloseBlock);
|
66
|
+
var isNoCloseParent = Volta._closest(e.target,'.' + _class.noCloseLink, _class.link) || Volta._closest(e.target,'.' + _class.noCloseBlock, _class.noCloseBlock);
|
67
|
+
var isInput = e.target instanceof HTMLInputElement;
|
68
|
+
|
69
|
+
if(!targetIsPanel && !parentIsPanel && !parentIsLink && !isNoClose && !isInput && !isNoCloseParent) {
|
70
|
+
e.preventDefault();
|
71
|
+
e.stopPropagation();
|
72
|
+
}
|
73
|
+
|
74
|
+
if(isSwitchSlider || isParentSwitch || isNoClose || isInput || isNoCloseParent) {
|
75
|
+
return null;
|
76
|
+
}
|
77
|
+
|
78
|
+
var text;
|
79
|
+
if(parentIsPanel && Volta._hasClass(e.target, _class.label)) {
|
80
|
+
text = e.target.innerHTML;
|
81
|
+
} else if (parentIsPanel) {
|
82
|
+
var label = e.target.querySelector('.' + _class.label);
|
83
|
+
if(label) {
|
84
|
+
text = label.innerHTML;
|
85
|
+
}
|
86
|
+
}
|
87
|
+
|
88
|
+
this.close(text);
|
89
|
+
|
90
|
+
document.querySelector('body').removeEventListener('click', this._closeEventHandler );
|
91
|
+
},
|
92
|
+
open: function(event) {
|
93
|
+
if(event) {
|
94
|
+
event.preventDefault();
|
95
|
+
event.stopPropagation();
|
96
|
+
}
|
97
|
+
|
98
|
+
this.dropdown.classList.add(_class.expanded);
|
99
|
+
|
100
|
+
if(!this._suppress){
|
101
|
+
this._closeEventHandler = this._closeEvent.bind(this);
|
102
|
+
document.querySelector('body').addEventListener('click', this._closeEventHandler );
|
103
|
+
}
|
104
|
+
},
|
105
|
+
_setDropdownSelectionText: function(text) {
|
106
|
+
if(this.isSelectionVisible) {
|
107
|
+
this.selection.innerText = text;
|
108
|
+
} else {
|
109
|
+
this.btn.innerText = text;
|
110
|
+
this.btn.value = text;
|
111
|
+
}
|
112
|
+
},
|
113
|
+
_suppress: false
|
114
|
+
}
|
115
|
+
|
116
|
+
return {
|
117
|
+
create: create,
|
118
|
+
init: attachDropdownHandlers
|
119
|
+
}
|
120
|
+
|
121
|
+
/**
|
122
|
+
* @public
|
123
|
+
*
|
124
|
+
* @description Attach a listeners to dropdowns
|
125
|
+
*/
|
126
|
+
function attachDropdownHandlers() {
|
127
|
+
document.querySelectorAll('.' + _class.wrapper).forEach(attachHandler);
|
128
|
+
|
129
|
+
function attachHandler(dropdown) {
|
130
|
+
create(dropdown);
|
131
|
+
}
|
132
|
+
}
|
133
|
+
|
134
|
+
/**
|
135
|
+
* @private
|
136
|
+
*
|
137
|
+
* @description Create a dropdown element
|
138
|
+
* @param {HTMLElement} element
|
139
|
+
*/
|
140
|
+
function create(element){
|
141
|
+
var dropdown = Object.create(Dropdown.prototype, {})
|
142
|
+
dropdown.init(element);
|
143
|
+
return dropdown;
|
144
|
+
}
|
145
|
+
}();
|
@@ -5,10 +5,11 @@
|
|
5
5
|
<script src="/assets/javascripts/volta.accordion.js"></script>
|
6
6
|
<script src="/assets/javascripts/volta.tabs.js"></script>
|
7
7
|
<script src="/assets/javascripts/volta.modal.js"></script>
|
8
|
+
<script src="/assets/javascripts/volta.dropdown.js"></script>
|
8
9
|
<script src="/assets/javascripts/volta.tooltip.js"></script>
|
9
10
|
<script src="/assets/javascripts/nexmo-oas-renderer.js?a=1"></script>
|
10
11
|
<script src="/assets/javascripts/components/format.js"></script>
|
11
12
|
<script type="text/javascript">
|
12
|
-
Volta.init(["accordion", "tab", "modal", "tooltip"]);
|
13
|
+
Volta.init(["accordion", "tab", "modal", "tooltip", "dropdown"]);
|
13
14
|
new Format
|
14
15
|
</script>
|
@@ -39,6 +39,20 @@
|
|
39
39
|
</div>
|
40
40
|
</div>
|
41
41
|
|
42
|
+
|
43
|
+
<% if @specification.groups.size > 1 %>
|
44
|
+
<h4>Jump to:</h4>
|
45
|
+
<div style="margin-bottom: 30px; padding: 8px;">
|
46
|
+
<% @specification.groups.each do |name, endpoints| %>
|
47
|
+
<% if name %>
|
48
|
+
<% group = definition.raw['tags'].detect { |tag| tag['name'].capitalize == name.capitalize } %>
|
49
|
+
<p><a href="#<%= group['name'].parameterize %>"><%= group['name'] %> »</a></p>
|
50
|
+
<p class="Vlt-grey-darker"><%= group['description']&.render_markdown %></p>
|
51
|
+
<% end %>
|
52
|
+
<% end %>
|
53
|
+
</div>
|
54
|
+
<% end %>
|
55
|
+
|
42
56
|
<%
|
43
57
|
# If there's only one group, everything is untagged
|
44
58
|
if @specification.groups.size === 1
|
@@ -39,9 +39,10 @@
|
|
39
39
|
|
40
40
|
<%
|
41
41
|
# This can likely be better done as a presenter, but it works for now
|
42
|
-
|
42
|
+
request = endpoint.request_body.content[format]['schema']
|
43
|
+
schema = request['oneOf']
|
43
44
|
%>
|
44
|
-
<%= erb :'open_api/_tabbed_parameters', locals: { body: endpoint.request_body, schema: schema, format: format, callback: callback } %>
|
45
|
+
<%= erb :'open_api/_tabbed_parameters', locals: { body: endpoint.request_body, request: request, schema: schema, format: format, callback: callback } %>
|
45
46
|
<%
|
46
47
|
end
|
47
48
|
end
|
@@ -1,18 +1,16 @@
|
|
1
|
-
<%
|
1
|
+
<%
|
2
|
+
tabs = Nexmo::OAS::Renderer::Presenters::ResponseTabs.new(format, response, content, endpoint, theme_light: @theme_light)
|
2
3
|
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
<% end %>
|
17
|
-
</div>
|
18
|
-
</div>
|
4
|
+
switcher = Nexmo::OAS::Renderer::Presenters::ContentSwitcher.new(label: "Response Example", format: format, force_type: tabs.switcher, theme_light: @theme_light)
|
5
|
+
|
6
|
+
tabs.tab_links.each_with_index do |v,k|
|
7
|
+
switcher.add_content(
|
8
|
+
title: v.content,
|
9
|
+
content: (erb *tabs.tab_panels[k].content),
|
10
|
+
tab_id: v.data_tab_link,
|
11
|
+
active: k == 0
|
12
|
+
)
|
13
|
+
end
|
14
|
+
%>
|
15
|
+
|
16
|
+
<%= erb *switcher.render %>
|
@@ -12,8 +12,7 @@
|
|
12
12
|
s
|
13
13
|
end
|
14
14
|
|
15
|
-
|
16
|
-
panels = []
|
15
|
+
switcher = Nexmo::OAS::Renderer::Presenters::ContentSwitcher.new(label: "Request Details", format: format, force_type: request['x-switcher'], theme_light: @theme_light)
|
17
16
|
|
18
17
|
schemas.each_with_index do |schema, index|
|
19
18
|
if schema['properties']
|
@@ -25,40 +24,21 @@
|
|
25
24
|
end
|
26
25
|
end
|
27
26
|
|
28
|
-
|
29
|
-
|
30
|
-
'
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
27
|
+
|
28
|
+
if schema['oneOf']
|
29
|
+
content = (erb :'open_api/_tabbed_parameters', locals: { body: body, request: schema, schema: schema['oneOf'], format: format, callback: callback })
|
30
|
+
else
|
31
|
+
content = (erb :'open_api/_parameters', locals: { parameters: schema['properties'], callback: callback })
|
32
|
+
end
|
33
|
+
|
34
|
+
switcher.add_content(
|
35
|
+
title: schema['title'] || schema['description'],
|
36
|
+
content: content,
|
37
|
+
tab_id: schema['x-tab-id'],
|
38
|
+
active: index == 0
|
39
|
+
)
|
35
40
|
end
|
36
41
|
%>
|
37
42
|
|
38
|
-
|
39
|
-
<div class="Vlt-tabs__header" role="tablist" aria-label="Responses">
|
40
|
-
<% panels.each do |panel| %>
|
41
|
-
<div role="tab" data-tab-link="<%= panel['x-tab-id'] %>" class="Vlt-tabs__link <%= panel['active'] ? 'Vlt-tabs__link_active' : '' %>">
|
42
|
-
<%= panel['description'] %>
|
43
|
-
</div>
|
44
|
-
<% end %>
|
45
|
-
</div>
|
46
|
-
<div class="Vlt-tabs__content">
|
47
|
-
<% panels.each do |panel| %>
|
48
|
-
<div class="Vlt-tabs__panel <%= panel['active'] ? 'Vlt-tabs__panel_active' : '' %>">
|
49
|
-
<%
|
50
|
-
# Nested oneOf?
|
51
|
-
if panel['oneOf']
|
52
|
-
%>
|
53
|
-
<%= erb :'open_api/_tabbed_parameters', locals: { body: body, schema: panel['oneOf'], format: format, callback: callback } %>
|
54
|
-
<%
|
55
|
-
else
|
56
|
-
%>
|
57
|
-
|
58
|
-
<%= erb :'open_api/_parameters', locals: { parameters: panel['parameters'], callback: callback } %>
|
59
|
-
<% end %>
|
60
|
-
</div>
|
61
|
-
<% end %>
|
62
|
-
</div>
|
63
|
-
</div>
|
43
|
+
<%= erb *switcher.render %>
|
64
44
|
|
@@ -0,0 +1,22 @@
|
|
1
|
+
<div class="Vlt-dropdown Vlt-dropdown--full-width">
|
2
|
+
<div class="Vlt-dropdown__trigger Vlt-dropdown__trigger--btn"><button class="Vlt-btn Vlt-btn--<%= (theme_light ? "secondary" : "tertiary") %>"><%= label %>: <span class="Vlt-dropdown__selection"><%= panels[0]['title'] %></span></button></div>
|
3
|
+
<div class="Vlt-dropdown__panel">
|
4
|
+
<div data-tab-content="<%= switcher.id %>" class="Vlt-dropdown__panel__content">
|
5
|
+
<% panels.each do |panel| %>
|
6
|
+
<div role="tab" data-tab-link="<%= panel['x-tab-id'] || panel['title'].parameterize %>" class="Vlt-dropdown__link Vlt-dropdown__label Vlt-js-tabs__link"><%= panel['title'] %></div>
|
7
|
+
<% end %>
|
8
|
+
</div>
|
9
|
+
</div>
|
10
|
+
</div>
|
11
|
+
|
12
|
+
|
13
|
+
<div class="js-format" data-format="<%= format %>">
|
14
|
+
<div id="<%= switcher.id %>" class="Vlt-js-tabs__content">
|
15
|
+
<% panels.each do |panel| %>
|
16
|
+
<div class="Vlt-js-tabs__panel <%= panel['active'] ? 'Vlt-js-tabs__panel_active' : '' %>">
|
17
|
+
<%= panel['content'] %>
|
18
|
+
</div>
|
19
|
+
<% end %>
|
20
|
+
</div>
|
21
|
+
</div>
|
22
|
+
|
@@ -0,0 +1,18 @@
|
|
1
|
+
<div class="Vlt-tabs js-format" data-format="<%= format %>">
|
2
|
+
<div class="Vlt-tabs__header" role="tablist" aria-label="<%= label %>">
|
3
|
+
<% panels.each do |panel| %>
|
4
|
+
<div role="tab" data-tab-link="<%= panel['x-tab-id'] || panel['title'].parameterize %>" class="Vlt-tabs__link <%= panel['active'] ? 'Vlt-tabs__link_active' : '' %>">
|
5
|
+
<%= panel['title'] %>
|
6
|
+
</div>
|
7
|
+
<% end %>
|
8
|
+
</div>
|
9
|
+
<div class="Vlt-tabs__content">
|
10
|
+
<% panels.each do |panel| %>
|
11
|
+
<div class="Vlt-tabs__panel <%= panel['active'] ? 'Vlt-tabs__panel_active' : '' %>">
|
12
|
+
<%= panel['content'] %>
|
13
|
+
</div>
|
14
|
+
<% end %>
|
15
|
+
</div>
|
16
|
+
</div>
|
17
|
+
|
18
|
+
|
data/nexmo-oas-renderer.gemspec
CHANGED
@@ -25,7 +25,7 @@ Gem::Specification.new do |spec|
|
|
25
25
|
# Specify which files should be added to the gem when it is released.
|
26
26
|
# The `git ls-files -z` loads the files in the RubyGem that have been added into git.
|
27
27
|
spec.files = Dir.chdir(File.expand_path(__dir__)) do
|
28
|
-
`git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
|
28
|
+
`git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features|samples)/}) }
|
29
29
|
end
|
30
30
|
spec.bindir = 'exe'
|
31
31
|
spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: nexmo-oas-renderer
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 2.3.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Fabian Rodriguez
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-
|
11
|
+
date: 2020-10-14 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activemodel
|
@@ -243,6 +243,7 @@ extensions: []
|
|
243
243
|
extra_rdoc_files: []
|
244
244
|
files:
|
245
245
|
- ".env.example"
|
246
|
+
- ".github/workflows/pull_request-review.yml"
|
246
247
|
- ".github/workflows/push-docker-publish.yml"
|
247
248
|
- ".gitignore"
|
248
249
|
- ".rspec"
|
@@ -254,8 +255,10 @@ files:
|
|
254
255
|
- Gemfile
|
255
256
|
- Gemfile.lock
|
256
257
|
- LICENSE.txt
|
258
|
+
- Procfile
|
257
259
|
- README.md
|
258
260
|
- Rakefile
|
261
|
+
- app.json
|
259
262
|
- bin/console
|
260
263
|
- bin/setup
|
261
264
|
- exe/nexmo-oas-renderer
|
@@ -271,6 +274,7 @@ files:
|
|
271
274
|
- lib/nexmo/oas/renderer/helpers/summary.rb
|
272
275
|
- lib/nexmo/oas/renderer/helpers/url.rb
|
273
276
|
- lib/nexmo/oas/renderer/presenters/api_specification.rb
|
277
|
+
- lib/nexmo/oas/renderer/presenters/content_switcher.rb
|
274
278
|
- lib/nexmo/oas/renderer/presenters/endpoint.rb
|
275
279
|
- lib/nexmo/oas/renderer/presenters/groups.rb
|
276
280
|
- lib/nexmo/oas/renderer/presenters/navigation.rb
|
@@ -300,6 +304,7 @@ files:
|
|
300
304
|
- lib/nexmo/oas/renderer/public/assets/javascripts/tooltip.min.js
|
301
305
|
- lib/nexmo/oas/renderer/public/assets/javascripts/volta.accordion.js
|
302
306
|
- lib/nexmo/oas/renderer/public/assets/javascripts/volta.core.js
|
307
|
+
- lib/nexmo/oas/renderer/public/assets/javascripts/volta.dropdown.js
|
303
308
|
- lib/nexmo/oas/renderer/public/assets/javascripts/volta.modal.js
|
304
309
|
- lib/nexmo/oas/renderer/public/assets/javascripts/volta.tabs.js
|
305
310
|
- lib/nexmo/oas/renderer/public/assets/javascripts/volta.tooltip.js
|
@@ -366,6 +371,8 @@ files:
|
|
366
371
|
- lib/nexmo/oas/renderer/views/open_api/_tabbed_parameters.erb
|
367
372
|
- lib/nexmo/oas/renderer/views/open_api/_tabbed_single_parameter.erb
|
368
373
|
- lib/nexmo/oas/renderer/views/open_api/_webhooks.erb
|
374
|
+
- lib/nexmo/oas/renderer/views/open_api/content_switcher/_dropdown.erb
|
375
|
+
- lib/nexmo/oas/renderer/views/open_api/content_switcher/_tabs.erb
|
369
376
|
- lib/nexmo/oas/renderer/views/open_api/show.erb
|
370
377
|
- lib/nexmo/oas/renderer/views/static/404.erb
|
371
378
|
- nexmo-oas-renderer.gemspec
|
@@ -390,7 +397,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
390
397
|
- !ruby/object:Gem::Version
|
391
398
|
version: '0'
|
392
399
|
requirements: []
|
393
|
-
|
400
|
+
rubyforge_project:
|
401
|
+
rubygems_version: 2.7.6.2
|
394
402
|
signing_key:
|
395
403
|
specification_version: 4
|
396
404
|
summary: OpenAPI Specification renderer.
|