openapi-explorer 0.9.310 → 0.9.314

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.
Files changed (121) hide show
  1. package/CHANGELOG.md +1 -0
  2. package/dist/{openapi-explorer.min.js → browser/openapi-explorer.min.js} +3 -3
  3. package/dist/{openapi-explorer.min.js.map → browser/openapi-explorer.min.js.map} +0 -0
  4. package/dist/es/components/api-request.js +936 -0
  5. package/dist/es/components/api-response.js +184 -0
  6. package/dist/es/components/json-tree.js +67 -0
  7. package/{src → dist/es}/components/mime-types.js +11 -17
  8. package/dist/es/components/schema-table.js +156 -0
  9. package/dist/es/components/schema-tree.js +191 -0
  10. package/dist/es/components/tag-input.js +67 -0
  11. package/{src → dist/es}/openapi-explorer-oauth-handler.js +2 -2
  12. package/{src → dist/es}/openapi-explorer.js +364 -371
  13. package/dist/es/styles/advanced-search-styles.js +2 -0
  14. package/dist/es/styles/api-request-styles.js +2 -0
  15. package/dist/es/styles/border-styles.js +2 -0
  16. package/dist/es/styles/endpoint-styles.js +2 -0
  17. package/dist/es/styles/flex-styles.js +2 -0
  18. package/dist/es/styles/font-styles.js +2 -0
  19. package/dist/es/styles/info-styles.js +2 -0
  20. package/dist/es/styles/input-styles.js +4 -0
  21. package/dist/es/styles/nav-styles.js +2 -0
  22. package/dist/es/styles/prism-styles.js +2 -0
  23. package/dist/es/styles/schema-styles.js +2 -0
  24. package/dist/es/styles/tab-styles.js +2 -0
  25. package/dist/es/styles/table-styles.js +2 -0
  26. package/dist/es/templates/advance-search-template.js +37 -0
  27. package/dist/es/templates/callback-template.js +7 -0
  28. package/dist/es/templates/code-samples-template.js +26 -0
  29. package/dist/es/templates/components-template.js +17 -0
  30. package/dist/es/templates/endpoint-template.js +94 -0
  31. package/dist/es/templates/expanded-endpoint-template.js +32 -0
  32. package/{src → dist/es}/templates/focused-endpoint-template.js +15 -15
  33. package/dist/es/templates/navbar-template.js +46 -0
  34. package/dist/es/templates/overview-template.js +9 -0
  35. package/dist/es/templates/responsiveViewMainBodyTemplate.js +30 -0
  36. package/dist/es/templates/security-scheme-template.js +330 -0
  37. package/dist/es/templates/server-template.js +42 -0
  38. package/{src → dist/es}/utils/color-utils.js +53 -16
  39. package/{src → dist/es}/utils/common-utils.js +18 -18
  40. package/{src → dist/es}/utils/schema-utils.js +248 -124
  41. package/{src → dist/es}/utils/spec-parser.js +112 -71
  42. package/dist/es/utils/theme.js +75 -0
  43. package/{src → dist/es}/utils/xml/xml.js +41 -38
  44. package/dist/lib/components/api-request.js +957 -0
  45. package/dist/lib/components/api-response.js +206 -0
  46. package/dist/lib/components/json-tree.js +82 -0
  47. package/dist/lib/components/mime-types.js +70 -0
  48. package/dist/lib/components/schema-table.js +170 -0
  49. package/dist/lib/components/schema-tree.js +206 -0
  50. package/dist/lib/components/tag-input.js +76 -0
  51. package/dist/lib/openapi-explorer-oauth-handler.js +19 -0
  52. package/dist/lib/openapi-explorer.js +817 -0
  53. package/dist/lib/styles/advanced-search-styles.js +10 -0
  54. package/dist/lib/styles/api-request-styles.js +10 -0
  55. package/dist/lib/styles/border-styles.js +10 -0
  56. package/dist/lib/styles/endpoint-styles.js +10 -0
  57. package/dist/lib/styles/flex-styles.js +10 -0
  58. package/dist/lib/styles/font-styles.js +10 -0
  59. package/dist/lib/styles/info-styles.js +10 -0
  60. package/dist/lib/styles/input-styles.js +11 -0
  61. package/dist/lib/styles/nav-styles.js +10 -0
  62. package/dist/lib/styles/prism-styles.js +10 -0
  63. package/dist/lib/styles/schema-styles.js +10 -0
  64. package/dist/lib/styles/tab-styles.js +10 -0
  65. package/dist/lib/styles/table-styles.js +10 -0
  66. package/dist/lib/templates/advance-search-template.js +42 -0
  67. package/dist/lib/templates/callback-template.js +12 -0
  68. package/dist/lib/templates/code-samples-template.js +36 -0
  69. package/dist/lib/templates/components-template.js +27 -0
  70. package/dist/lib/templates/endpoint-template.js +111 -0
  71. package/dist/lib/templates/expanded-endpoint-template.js +48 -0
  72. package/dist/lib/templates/focused-endpoint-template.js +95 -0
  73. package/dist/lib/templates/navbar-template.js +54 -0
  74. package/dist/lib/templates/overview-template.js +16 -0
  75. package/dist/lib/templates/responsiveViewMainBodyTemplate.js +47 -0
  76. package/dist/lib/templates/security-scheme-template.js +342 -0
  77. package/dist/lib/templates/server-template.js +49 -0
  78. package/dist/lib/utils/color-utils.js +112 -0
  79. package/dist/lib/utils/common-utils.js +156 -0
  80. package/dist/lib/utils/schema-utils.js +743 -0
  81. package/dist/lib/utils/spec-parser.js +361 -0
  82. package/dist/lib/utils/theme.js +84 -0
  83. package/dist/lib/utils/xml/xml.js +239 -0
  84. package/package.json +19 -6
  85. package/dist/openapi-explorer.min.js.LICENSE.txt +0 -71
  86. package/dist/openapi-explorer.min.js.LICENSE.txt.gz +0 -0
  87. package/dist/openapi-explorer.min.js.gz +0 -0
  88. package/dist/openapi-explorer.min.js.map.gz +0 -0
  89. package/dist/report.html +0 -38
  90. package/src/components/api-request.js +0 -1244
  91. package/src/components/api-response.js +0 -340
  92. package/src/components/json-tree.js +0 -129
  93. package/src/components/schema-table.js +0 -250
  94. package/src/components/schema-tree.js +0 -280
  95. package/src/components/tag-input.js +0 -109
  96. package/src/styles/advanced-search-styles.js +0 -84
  97. package/src/styles/api-request-styles.js +0 -111
  98. package/src/styles/border-styles.js +0 -24
  99. package/src/styles/css/main.css +0 -24
  100. package/src/styles/endpoint-styles.js +0 -222
  101. package/src/styles/flex-styles.js +0 -15
  102. package/src/styles/font-styles.js +0 -266
  103. package/src/styles/info-styles.js +0 -20
  104. package/src/styles/input-styles.js +0 -236
  105. package/src/styles/nav-styles.js +0 -141
  106. package/src/styles/prism-styles.js +0 -107
  107. package/src/styles/schema-styles.js +0 -121
  108. package/src/styles/tab-styles.js +0 -44
  109. package/src/styles/table-styles.js +0 -48
  110. package/src/templates/advance-search-template.js +0 -81
  111. package/src/templates/callback-template.js +0 -63
  112. package/src/templates/code-samples-template.js +0 -35
  113. package/src/templates/components-template.js +0 -43
  114. package/src/templates/endpoint-template.js +0 -175
  115. package/src/templates/expanded-endpoint-template.js +0 -104
  116. package/src/templates/navbar-template.js +0 -175
  117. package/src/templates/overview-template.js +0 -58
  118. package/src/templates/responsiveViewMainBodyTemplate.js +0 -72
  119. package/src/templates/security-scheme-template.js +0 -487
  120. package/src/templates/server-template.js +0 -106
  121. package/src/utils/theme.js +0 -163
@@ -1,340 +0,0 @@
1
- import { LitElement, html, css } from 'lit-element';
2
- import { marked } from 'marked';
3
- import { unsafeHTML } from 'lit-html/directives/unsafe-html';
4
- import { schemaInObjectNotation, generateExample } from '../utils/schema-utils';
5
- import FontStyles from '../styles/font-styles';
6
- import FlexStyles from '../styles/flex-styles';
7
- import TableStyles from '../styles/table-styles';
8
- import InputStyles from '../styles/input-styles';
9
- import TabStyles from '../styles/tab-styles';
10
- import BorderStyles from '../styles/border-styles';
11
- import './schema-tree';
12
- import './schema-table';
13
-
14
- export default class ApiResponse extends LitElement {
15
- constructor() {
16
- super();
17
- this.selectedStatus = '';
18
- this.headersForEachRespStatus = {};
19
- this.mimeResponsesForEachStatus = {};
20
- this.activeSchemaTab = 'model';
21
- }
22
-
23
- static get properties() {
24
- return {
25
- callback: { type: String },
26
- responses: { type: Object },
27
- parser: { type: Object },
28
- schemaStyle: { type: String, attribute: 'schema-style' },
29
- renderStyle: { type: String, attribute: 'render-style' },
30
- selectedStatus: { type: String, attribute: 'selected-status' },
31
- selectedMimeType: { type: String, attribute: 'selected-mime-type' },
32
- activeSchemaTab: { type: String, attribute: 'active-schema-tab' },
33
- schemaExpandLevel: { type: Number, attribute: 'schema-expand-level' },
34
- schemaDescriptionExpanded: { type: String, attribute: 'schema-description-expanded' },
35
- schemaHideWriteOnly: { type: String, attribute: 'schema-hide-write-only' },
36
- };
37
- }
38
-
39
- static get styles() {
40
- return [
41
- FontStyles,
42
- FlexStyles,
43
- TabStyles,
44
- TableStyles,
45
- InputStyles,
46
- BorderStyles,
47
- css`
48
- .resp-head{
49
- vertical-align: middle;
50
- padding:16px 0 8px;
51
- }
52
- .resp-head.divider{
53
- border-top: 1px solid var(--border-color);
54
- margin-top:10px;
55
- }
56
- .resp-status{
57
- font-weight:bold;
58
- font-size:calc(var(--font-size-small) + 1px);
59
- }
60
- .resp-descr{
61
- font-size:calc(var(--font-size-small) + 1px);
62
- }
63
- .top-gap{margin-top:16px;}
64
- .example-panel{
65
- font-size:var(--font-size-small);
66
- margin:0;
67
- }
68
- .generic-tree {
69
- background: rgb(51, 51, 51);
70
- color: white;
71
- }
72
- .example-panel.generic-tree {
73
- margin-top: 8px;
74
- }
75
- pre.generic-tree {
76
- border: none;
77
- padding: 8px 10px 10px;
78
- }
79
- .example-panel select {
80
- margin-left: 8px;
81
- padding-top: 8px;
82
- min-width: 100px;
83
- max-width: 100%
84
- }
85
- .example-panel .example {
86
- padding-top: 8px;
87
- }
88
- .focused-mode,
89
- .read-mode {
90
- padding-top:24px;
91
- margin-top:12px;
92
- border-top: 1px dashed var(--border-color);
93
- }`,
94
- ];
95
- }
96
-
97
- render() {
98
- return html`
99
- <div class="col regular-font response-panel ${this.renderStyle}-mode">
100
- <div class=" ${this.callback === 'true' ? 'tiny-title' : 'req-res-title'} ">
101
- ${this.callback === 'true' ? 'CALLBACK RESPONSE' : 'RESPONSE'}
102
- </div>
103
- <div>
104
- ${this.responseTemplate()}
105
- <div>
106
- </div>
107
- `;
108
- }
109
-
110
- resetSelection() {
111
- this.selectedStatus = '';
112
- this.selectedMimeType = '';
113
- }
114
-
115
- /* eslint-disable indent */
116
- responseTemplate() {
117
- if (!this.responses) { return ''; }
118
- for (const statusCode in this.responses) {
119
- if (!this.selectedStatus) {
120
- this.selectedStatus = statusCode;
121
- }
122
- const allMimeResp = {};
123
- for (const mimeResp in (this.responses[statusCode] && this.responses[statusCode].content)) {
124
- const mimeRespObj = this.responses[statusCode].content[mimeResp];
125
- if (!this.selectedMimeType) {
126
- this.selectedMimeType = mimeResp;
127
- }
128
- // Generate Schema
129
- const schemaTree = schemaInObjectNotation(mimeRespObj.schema, {});
130
- // Generate Example
131
- const respExamples = generateExample(
132
- (mimeRespObj.examples || ''),
133
- (mimeRespObj.example || ''),
134
- mimeRespObj.schema,
135
- mimeResp,
136
- true,
137
- false,
138
- mimeResp.includes('json') ? 'json' : 'text',
139
- );
140
- allMimeResp[mimeResp] = {
141
- description: this.responses[statusCode].description,
142
- examples: respExamples,
143
- selectedExample: respExamples[0] && respExamples[0].exampleId || '',
144
- schemaTree,
145
- };
146
- }
147
- // Headers for each response status
148
- const tempHeaders = [];
149
- for (const key in this.responses[statusCode] && this.responses[statusCode].headers) {
150
- tempHeaders.push({ name: key, ...this.responses[statusCode].headers[key] });
151
- }
152
- this.headersForEachRespStatus[statusCode] = tempHeaders;
153
- this.mimeResponsesForEachStatus[statusCode] = allMimeResp;
154
- }
155
- return html`<div class='row' style='flex-wrap:wrap'>
156
- ${Object.keys(this.responses).map((respStatus) => html`
157
- ${respStatus === '$$ref' // Swagger-Client parser creates '$$ref' object if JSON references are used to create responses - this should be ignored
158
- ? ''
159
- : html`
160
- <button
161
- @click="${() => {
162
- this.selectedStatus = respStatus;
163
- if (this.responses[respStatus].content && Object.keys(this.responses[respStatus].content)[0]) {
164
- this.selectedMimeType = Object.keys(this.responses[respStatus].content)[0];
165
- } else {
166
- this.selectedMimeType = undefined;
167
- }
168
- }}"
169
- class='m-btn small ${this.selectedStatus === respStatus ? 'primary' : ''}'
170
- part="btn--resp ${this.selectedStatus === respStatus ? 'btn-fill--resp' : 'btn-outline--resp'} btn-response-status"
171
- style='margin: 8px 4px 0 0'
172
- >
173
- ${respStatus}
174
- </button>`
175
- }`)
176
- }
177
- </div>
178
-
179
- ${Object.keys(this.responses).map((status) => html`
180
- <div style = 'display: ${status === this.selectedStatus ? 'block' : 'none'}' >
181
- <div class="top-gap">
182
- <span class="resp-descr m-markdown ">${unsafeHTML(marked(this.responses[status] && this.responses[status].description || ''))}</span>
183
- ${(this.headersForEachRespStatus[status] && this.headersForEachRespStatus[status].length > 0)
184
- ? html`${this.responseHeaderListTemplate(this.headersForEachRespStatus[status])}`
185
- : ''
186
- }
187
- </div>
188
- ${Object.keys(this.mimeResponsesForEachStatus[status]).length === 0
189
- ? ''
190
- : html`
191
- <div class="tab-panel col">
192
- <div class="tab-buttons row" @click="${(e) => { if (e.target.tagName.toLowerCase() === 'button') { this.activeSchemaTab = e.target.dataset.tab; } }}" >
193
- <button class="tab-btn ${this.activeSchemaTab === 'model' ? 'active' : ''}" data-tab='model'>MODEL</button>
194
- <button class="tab-btn ${this.activeSchemaTab === 'body' ? 'active' : ''}" data-tab='body'>EXAMPLE</button>
195
- <div style="flex:1"></div>
196
- ${Object.keys(this.mimeResponsesForEachStatus[status]).length === 1
197
- ? html`<span class='small-font-size gray-text' style='align-self:center; margin-top:8px;'> ${Object.keys(this.mimeResponsesForEachStatus[status])[0]} </span>`
198
- : html`${this.mimeTypeDropdownTemplate(Object.keys(this.mimeResponsesForEachStatus[status]))}`
199
- }
200
- </div>
201
- ${this.activeSchemaTab === 'body'
202
- ? html`<div class='tab-content col' style='flex:1;'>
203
- ${this.mimeExampleTemplate(this.mimeResponsesForEachStatus[status][this.selectedMimeType])}
204
- </div>`
205
- : html`<div class='tab-content col' style='flex:1;'>
206
- ${this.mimeSchemaTemplate(this.mimeResponsesForEachStatus[status][this.selectedMimeType])}
207
- </div>`
208
- }
209
- </div>
210
- `
211
- }`)
212
- }
213
- `;
214
- }
215
-
216
- responseHeaderListTemplate(respHeaders) {
217
- return html`
218
- <div style="padding:16px 0 8px 0" class="resp-headers small-font-size bold-text">RESPONSE HEADERS</div>
219
- <table role="presentation" style="border-collapse: collapse; margin-bottom:16px; border:1px solid var(--border-color); border-radius: var(--border-radius)" class="small-font-size mono-font">
220
- ${respHeaders.map((v) => html`
221
- <tr>
222
- <td style="padding:8px; vertical-align: baseline; min-width:120px; border-top: 1px solid var(--light-border-color); text-overflow: ellipsis;">
223
- ${v.name || ''}
224
- </td>
225
- <td style="padding:4px; vertical-align: baseline; padding:0 5px; border-top: 1px solid var(--light-border-color); text-overflow: ellipsis;">
226
- ${v.schema.type || ''}
227
- </td>
228
- <td style="padding:8px; vertical-align: baseline; border-top: 1px solid var(--light-border-color);text-overflow: ellipsis;">
229
- <div class="m-markdown-small regular-font" >${unsafeHTML(marked(v.description || ''))}</div>
230
- </td>
231
- <td style="padding:8px; vertical-align: baseline; border-top: 1px solid var(--light-border-color); text-overflow: ellipsis;">
232
- ${v.schema.example || ''}
233
- </td>
234
- </tr>
235
- `)}
236
- </table>`;
237
- }
238
-
239
- mimeTypeDropdownTemplate(mimeTypes) {
240
- return html`
241
- <select aria-label='mime type' @change="${(e) => { this.selectedMimeType = e.target.value; }}" style='margin-bottom: -1px; z-index:1'>
242
- ${mimeTypes.map((mimeType) => html`<option value='${mimeType}' ?selected = '${mimeType === this.selectedMimeType}'> ${mimeType} </option>`)}
243
- </select>`;
244
- }
245
-
246
- onSelectExample(e) {
247
- const exampleContainerEl = e.target.closest('.example-panel');
248
- const exampleEls = [...exampleContainerEl.querySelectorAll('.example')];
249
-
250
- exampleEls.forEach((v) => {
251
- v.style.display = v.dataset.example === e.target.value ? 'block' : 'none';
252
- });
253
- }
254
-
255
- mimeExampleTemplate(mimeRespDetails) {
256
- if (!mimeRespDetails) {
257
- return html`
258
- <pre style='color:var(--red)' class = 'example-panel border-top'> No example provided </pre>
259
- `;
260
- }
261
- return html`
262
- ${mimeRespDetails.examples.length === 1
263
- ? html`
264
- ${mimeRespDetails.examples[0].exampleSummary && mimeRespDetails.examples[0].exampleSummary.length > 80 ? html`<div style="padding: 4px 0"> ${mimeRespDetails.examples[0].exampleSummary} </div>` : ''}
265
- ${mimeRespDetails.examples[0].exampleDescription ? html`<div class="m-markdown-small" style="padding: 4px 0"> ${unsafeHTML(marked(mimeRespDetails.examples[0].exampleDescription || ''))} </div>` : ''}
266
- ${mimeRespDetails.examples[0].exampleFormat === 'json'
267
- ? html`
268
- <json-tree
269
- render-style = '${this.renderStyle}'
270
- .data="${mimeRespDetails.examples[0].exampleValue}"
271
- class = 'example-panel pad-top-8'
272
- ></json-tree>`
273
- : html`
274
- <pre class = 'example-panel generic-tree border-top pad-top-8'>${mimeRespDetails.examples[0].exampleValue}</pre>
275
- `
276
- }`
277
- : html`
278
- <span class = 'example-panel generic-tree ${this.renderStyle === 'read' ? 'border pad-8-16' : 'border-top pad-top-8'}'>
279
- <select aria-label='response body example' @change='${(e) => this.onSelectExample(e)}'>
280
- ${mimeRespDetails.examples.map((v) => html`<option value="${v.exampleId}" ?selected=${v.exampleId === mimeRespDetails.selectedExample} >
281
- ${v.exampleSummary.length > 80 ? v.exampleId : v.exampleSummary}
282
- </option>`)}
283
- </select>
284
- ${mimeRespDetails.examples.map((v) => html`
285
- <div class="example" data-example = '${v.exampleId}' style = "display: ${v.exampleId === mimeRespDetails.selectedExample ? 'block' : 'none'}">
286
- ${v.exampleSummary && v.exampleSummary.length > 80 ? html`<div style="padding: 4px 0"> ${v.exampleSummary} </div>` : ''}
287
- ${v.exampleDescription ? html`<div class="m-markdown-small" style="padding: 4px 0"> ${unsafeHTML(marked(v.exampleDescription || ''))} </div>` : ''}
288
- ${v.exampleFormat === 'json'
289
- ? html`
290
- <json-tree
291
- render-style = '${this.renderStyle}'
292
- .data = '${v.exampleValue}'
293
- ></json-tree>`
294
- : html`<pre class="generic-tree">${v.exampleValue}</pre>`
295
- }
296
- </div>
297
- `)}
298
- </span>
299
- `
300
- }
301
- `;
302
- }
303
-
304
- mimeSchemaTemplate(mimeRespDetails) {
305
- if (!mimeRespDetails) {
306
- return html`
307
- <pre style='color:var(--red)' class = '${this.renderStyle === 'read' ? 'border pad-8-16' : 'border-top'}'> Schema not found</pre>
308
- `;
309
- }
310
- return html`
311
- ${this.schemaStyle === 'table'
312
- ? html`
313
- <schema-table
314
- render-style = '${this.renderStyle}'
315
- .data = '${mimeRespDetails.schemaTree}'
316
- class = 'example-panel ${this.renderStyle === 'read' ? 'border pad-8-16' : 'border-top pad-top-8'}'
317
- schema-expand-level = "${this.schemaExpandLevel}"
318
- schema-description-expanded = "${this.schemaDescriptionExpanded}"
319
- schema-hide-read-only = false
320
- schema-hide-write-only = ${this.schemaHideWriteOnly}
321
- > </schema-tree> `
322
- : html`
323
- <schema-tree
324
- render-style = '${this.renderStyle}'
325
- .data = '${mimeRespDetails.schemaTree}'
326
- class = 'example-panel ${this.renderStyle === 'read' ? 'border pad-8-16' : 'pad-top-8'}'
327
- schema-expand-level = "${this.schemaExpandLevel}"
328
- schema-description-expanded = "${this.schemaDescriptionExpanded}"
329
- schema-hide-read-only = false
330
- schema-hide-write-only = ${this.schemaHideWriteOnly}
331
- > </schema-tree>`
332
- }`;
333
- }
334
- /* eslint-enable indent */
335
- }
336
-
337
- // Register the element with the browser
338
- if (!customElements.get('openapi-explorer')) {
339
- customElements.define('api-response', ApiResponse);
340
- }
@@ -1,129 +0,0 @@
1
- import { LitElement, html, css } from 'lit-element';
2
- import { copyToClipboard } from '../utils/common-utils';
3
- import FontStyles from '../styles/font-styles';
4
- import BorderStyles from '../styles/border-styles';
5
- import InputStyles from '../styles/input-styles';
6
-
7
- export default class JsonTree extends LitElement {
8
- static get properties() {
9
- return {
10
- data: { type: Object },
11
- renderStyle: { type: String, attribute: 'render-style' },
12
- };
13
- }
14
-
15
- static get styles() {
16
- return [
17
- FontStyles,
18
- BorderStyles,
19
- InputStyles,
20
- css`
21
- :host{
22
- display:flex;
23
- }
24
- .json-tree {
25
- background: rgb(51, 51, 51);
26
- color: white;
27
- padding: 8px;
28
-
29
- min-height: 30px;
30
- font-family: var(--font-mono);
31
- font-size: var(--font-size-small);
32
- overflow:hidden;
33
- word-break: break-all;
34
- flex:1;
35
- line-height: calc(var(--font-size-small) + 6px);
36
- }
37
-
38
- .open-bracket{
39
- display:inline-block;
40
- padding: 0 20px 0 0;
41
- cursor: pointer;
42
- border: 1px solid transparent;
43
- border-radius:3px;
44
- }
45
- .open-bracket:hover{
46
- color:var(--primary-color);
47
- background-color:var(--hover-color);
48
- border: 1px solid var(--border-color);
49
- }
50
- .inside-bracket{
51
- padding-left:16px;
52
- border-left:1px dotted var(--border-color);
53
- }
54
- .open-bracket.collapsed + .inside-bracket,
55
- .open-bracket.collapsed + .inside-bracket + .close-bracket {
56
- display:none;
57
- }
58
-
59
- .string{color:var(--green);}
60
- .number{color:var(--blue);}
61
- .null{color:var(--red);}
62
- .boolean{color:var(--orange);}
63
- .object{color:white}
64
-
65
- .toolbar {
66
- position: absolute;
67
- right:6px;
68
- display:flex;
69
- align-items: center;
70
- }`,
71
- ];
72
- }
73
-
74
- /* eslint-disable indent */
75
- render() {
76
- return html`
77
- <div class = "json-tree" >
78
- <div class='toolbar'>
79
- <button class="toolbar-copy-btn" part="btn btn-fill" @click='${(e) => { copyToClipboard(JSON.stringify(this.data, null, 2), e); }}'>Copy</button>
80
- </div>
81
- ${this.generateTree(this.data, true)}
82
- </div>
83
- `;
84
- }
85
-
86
- generateTree(data, isLast = false) {
87
- if (data === null) {
88
- return html`<div class="null" style="display:inline;">null</div>`;
89
- }
90
- if (typeof data === 'object' && (data instanceof Date === false)) {
91
- const detailType = Array.isArray(data) ? 'array' : 'pure_object';
92
- if (Object.keys(data).length === 0) {
93
- return html`${(Array.isArray(data) ? '[ ],' : '{ },')}`;
94
- }
95
- return html`
96
- <div class="open-bracket expanded ${detailType === 'array' ? 'array' : 'object'} " @click="${this.toggleExpand}" > ${detailType === 'array' ? '[' : '{'}</div>
97
- <div class="inside-bracket">
98
- ${Object.keys(data).map((key, i, a) => html`
99
- <div class="item">
100
- ${detailType === 'pure_object' ? html`"${key}":` : ''}
101
- ${this.generateTree(data[key], i === (a.length - 1))}
102
- </div>`)
103
- }
104
- </div>
105
- <div class="close-bracket">${detailType === 'array' ? ']' : '}'}${isLast ? '' : ','}</div>
106
- `;
107
- }
108
-
109
- return (typeof data === 'string' || data instanceof Date)
110
- ? html`<span class="${typeof data}">"${data}"</span>${isLast ? '' : ','}`
111
- : html`<span class="${typeof data}">${data}</span>${isLast ? '' : ','}`;
112
- }
113
- /* eslint-enable indent */
114
-
115
- toggleExpand(e) {
116
- const openBracketEl = e.target;
117
- if (openBracketEl.classList.contains('expanded')) {
118
- openBracketEl.classList.replace('expanded', 'collapsed');
119
- e.target.innerHTML = e.target.classList.contains('array') ? '[...]' : '{...}';
120
- } else {
121
- openBracketEl.classList.replace('collapsed', 'expanded');
122
- e.target.innerHTML = e.target.classList.contains('array') ? '[' : '{';
123
- }
124
- }
125
- }
126
- // Register the element with the browser
127
- if (!customElements.get('openapi-explorer')) {
128
- customElements.define('json-tree', JsonTree);
129
- }