Skip to content

Commit

Permalink
[W-12646073] fix collapsible behaviour (#40)
Browse files Browse the repository at this point in the history
* chore: fix collapsible behaviour

* 4.3.8

* chore: fix unit test
  • Loading branch information
alexpmule authored Nov 9, 2023
1 parent c8ec4c3 commit 82e78f0
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 25 deletions.
2 changes: 1 addition & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@api-components/api-resource-example-document",
"description": "A viewer for examples in a resource based on AMF model",
"version": "4.3.7",
"version": "4.3.8",
"license": "Apache-2.0",
"main": "index.js",
"module": "index.js",
Expand Down
2 changes: 1 addition & 1 deletion src/ApiResourceExampleDocument.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -217,5 +217,5 @@ export class ApiResourceExampleDocument extends AmfHelperMixin(LitElement) {

_exampleTitleIsMediaType(example: Example): boolean;

_handleCollapsePanel(): void;
_handleCollapsePanel(example: Example, index: Number): void;
}
48 changes: 27 additions & 21 deletions src/ApiResourceExampleDocument.js
Original file line number Diff line number Diff line change
Expand Up @@ -568,38 +568,40 @@ export class ApiResourceExampleDocument extends AmfHelperMixin(LitElement) {
}

/**
* @param {Example} example
* @param {number} index
* Collapse the current example panel
*/
_handleCollapsePanel() {
const examplePanel = this.shadowRoot.querySelector('.renderer')
const icon = this.shadowRoot.querySelector('.expand-icon')
icon.classList.toggle('expand-icon-collapse')
examplePanel.classList.toggle('collapse')

this._collapseExamplePanel = !this._collapseExamplePanel
_handleCollapsePanel(example, index) {
const examplePanels = this.shadowRoot.querySelectorAll('.renderer')
const icons = this.shadowRoot.querySelectorAll('.expand-icon')
icons[index].classList.toggle('expand-icon-collapse')
examplePanels[index].classList.toggle('collapse')
example.opened = !example.opened
}

/**
* @param {Example} example
* @returns {TemplateResult|string}
* @param {number} index
* @returns {TemplateResult|string}
*/
_titleTemplate(example) {
_titleTemplate(example, index) {
if (example.isScalar) {
return '';
}
const label = this._computeExampleTitle(example);
return html`<div
class="example-title"
@click="${this._handleCollapsePanel}"
@keyup="${this._handleCollapsePanel}"
@click="${() => this._handleCollapsePanel(example, index)}"
@keyup="${() => this._handleCollapsePanel(example, index)}"
>
<span>${label}</span>
<anypoint-icon-button
class="expand-icon-wrapper"
data-action="collapse"
title="Collapse panel"
>
<arc-icon class="expand-icon" icon="expandLess"></arc-icon>
<arc-icon class="expand-icon" icon="expandLess"></arc-icon>
</anypoint-icon-button>
</div>`;
}
Expand Down Expand Up @@ -630,7 +632,7 @@ export class ApiResourceExampleDocument extends AmfHelperMixin(LitElement) {

/**
* Returns title to render for example
* @param {Example} example
* @param {Example} example
* @returns {String} 'Example' or the example's title
*/
_computeExampleTitle(example) {
Expand All @@ -643,7 +645,7 @@ export class ApiResourceExampleDocument extends AmfHelperMixin(LitElement) {
/**
* Determines whether an example's title is just a variation
* of the current media type + a number
* @param {Example} example
* @param {Example} example
* @returns {Boolean}
*/
_exampleTitleIsMediaType(example) {
Expand All @@ -653,23 +655,27 @@ export class ApiResourceExampleDocument extends AmfHelperMixin(LitElement) {
}

/**
* @param {Example[]} examples
* @returns {TemplateResult[]}
* @param {Example[]} initialExamples
* @returns {TemplateResult[]}
*/
_examplesTemplate(examples) {
_examplesTemplate(initialExamples) {
const examples = initialExamples.map(example => {
example.opened = !!this._collapseExamplePanel
return example
});
let parts = 'content-action-button, code-content-action-button, content-action-button-disabled, ';
parts += 'code-content-action-button-disabled content-action-button-active, ';
parts += 'code-content-action-button-active, code-wrapper, example-code-wrapper, markdown-html';
return examples.map((item) => html`
return examples.map((example, index) => html`
<div class="item-container">
${this._titleTemplate(item)}
${this._descriptionTemplate(item)}
${this._titleTemplate(example, index)}
${this._descriptionTemplate(example)}
<div class="renderer">
<arc-icon class="info-icon" icon="code"></arc-icon>
<api-example-render
exportParts="${parts}"
class="example"
.example="${item}"
.example="${example}"
.mediaType="${this.mediaType}"
?isJson="${this.isJson}"
?table="${this.table}"
Expand Down
2 changes: 1 addition & 1 deletion test/api-resource-example-document.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -552,7 +552,7 @@ describe('ApiResourceExampleDocument', () => {
const expandIconNoCollapsed = /** @type HTMLElement */ (element.shadowRoot.querySelector('.expand-icon-collapse'));
assert.isNull(expandIconNoCollapsed);

setTimeout(() => element._handleCollapsePanel());
setTimeout(() => element._handleCollapsePanel(element.examples[0], 0));

const examplePanelCollapsed = /** @type HTMLElement */ (element.shadowRoot.querySelector('.collapse'));
assert.isDefined(examplePanelCollapsed);
Expand Down

0 comments on commit 82e78f0

Please sign in to comment.