Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enable device section folding #2233

Open
justjam2013 opened this issue Nov 8, 2024 · 15 comments
Open

Enable device section folding #2233

justjam2013 opened this issue Nov 8, 2024 · 15 comments

Comments

@justjam2013
Copy link
Contributor

justjam2013 commented Nov 8, 2024

Feature Description

For plugins using the Accessory Plugin template, when you have an multiple accessories, each accessory section in the configuration can be collapsed, as shown for these Dummy Switches:
Screenshot 2024-11-08 at 11 54 13 AM
This makes it easy to manage a large set of devices.

For plugins using the Platform Plugin template, when you have an array of accessories, each individual accessory section in the configuration is not collapsible, as shown:
Screenshot 2024-11-08 at 11 54 49 AM
This makes it harder to find a device in a large set of devices.

This enhancement suggests adding to the Platform Plugin template the default ability to expand/collapse the section of a singe device in an array.

Using form:

If you try to use the form section in config.schema.json, as specified in the JSON Schema Form spec, you can only expand/collapse the entire configuration, unless you fully manage the form layout, which means that dynamically showing/hiding fields through the use of condition fails completely

    "condition": {
        "functionBody": "return model.devices[arrayIndices].someField === true;"
    }

All collapsed:
Screenshot 2024-11-08 at 12 04 12 PM

All expanded:
Screenshot 2024-11-08 at 12 04 23 PM

Or you get the JSON Schema Form form and the Homebridge layout conflicting. Which means that if the out-of-the-box Homebridge layout changes, it can end up breaking plugin layouts:
Screenshot 2024-11-08 at 12 04 39 PM

@justjam2013
Copy link
Contributor Author

Adding expandable to array items causes the entire section to disappear and no expand button is displayed:

      "devices": {
        "title": "Accessories",
        "type": "array",
        "items": {
          "expandable": true,
          "type": "object",
          "properties": {

Screenshot 2024-11-08 at 1 24 27 PM

@LukeBurke99
Copy link

I would also appreciate this being implemented. After using the '[homebridge-virtual-accessories]' plugin and adding a few devices, you start to lose yourself in the number of fields shown.

Implementing the same functionality as the 'Accessory Plugin template' would be perfect

@justjam2013
Copy link
Contributor Author

justjam2013 commented Nov 27, 2024

Collapse expand is supported at the platform level in homebridge-config-ui-x/ui/src/app/core/manage-plugins/plugin-config/plugin-config.component.html for multiple platforms, where individual platforms can be extended/collapsed:

    <!-- MULTIPLE CONFIG BLOCKS-->
    <div
      ngbAccordion
      [closeOthers]="true"
      (show)="blockShown($event)"
      (hide)="blockHidden($event)"
      *ngIf="pluginConfig.length && !schema.singular"
    >
    ...
        <div ngbAccordionCollapse>
          <div ngbAccordionBody class="card-body">
            <app-schema-form [configSchema]="schema" [(data)]="block.config"> </app-schema-form>
          </div>
        </div>

Screenshot 2024-11-27 at 12 23 54 PM

Whereas it is not for single platforms:
Screenshot 2024-11-27 at 12 24 21 PM

I doubt that the recommended approach is to create a platform for each single accessory, otherwise there wouldn't be the option to add multiple accessories to a platform.

@justjam2013
Copy link
Contributor Author

Looking at the code, the multiple platform config section, wraps the individual platform card in an ngbAccordion div, then displays the platform card inside a ngbAccordionCollapse div (plugin-config.component.html - lines: 23, 65):

    <div
      ngbAccordion
      [closeOthers]="true"
      (show)="blockShown($event)"
      (hide)="blockHidden($event)"
      *ngIf="pluginConfig.length && !schema.singular"
    >
    ....
        <div ngbAccordionCollapse>
          <div ngbAccordionBody class="card-body">
            <app-schema-form [configSchema]="schema" [(data)]="block.config"> </app-schema-form>    # Wraps individual platform
          </div>
        </div>
    ....    

So it would be the case of wrapping the individual device card in the same ngbAccordion div and ngbAccordionCollapse div here (plugin-config.component.html - line: 74):

    <div *ngIf="pluginConfig.length && schema.singular" class="card card-body">
      <app-schema-form [configSchema]="schema" [(data)]="pluginConfig[0].config"> </app-schema-form>    # Wrap each accessory in an "ngbAccordion" div
      <app-homebridge-deconz *ngIf="plugin.name==='homebridge-deconz'"></app-homebridge-deconz>
      <app-homebridge-hue *ngIf="plugin.name==='homebridge-hue'"></app-homebridge-hue>
    </div>

@justjam2013
Copy link
Contributor Author

This functionality is supported for accessories, if the plugin type is accessory (homebridge-config-ui-x/ui/src/app/core/manage-plugins/plugin-config/plugin-config.component.ts), although the accessory plugin is deprecated for HB 2.0:

  public pluginType: 'platform' | 'accessory'

@justjam2013
Copy link
Contributor Author

This is supported by ajsf by adding "expandable": true, as a property for items array. Using Angular JSON Schema Form — Demonstration Playground with this schema:

{
  "schema":{
    "type": "object",
    "properties":{
      "name":{
        "title": "Platform Name",
        "type": "string",
        "required": true,
        "default": "Virtual Accessories Platform",
        "readonly": true
      },
      "devices":{
        "title": "Accessories",
        "type": "array",
        "orderable": true,
        "uniqueItemProperties": [ "accessoryID" ],
        "items":{
          "title": "Accessory",
          "expandable": true,            <----- this
          "type": "object",
          "properties":{
            "accessoryID":{
              "title": "Accessory ID",
              "description": "Unique ID for the Accessory (do not modify once assigned)",
              "type": "string",
              "required": true,
              "pattern": "^[A-Fa-f0-9\\-]{5,}$"
            },
            "accessoryName":{
              "title": "Accessory Name",
              "description": "Accessory name as it will be displayed in HomeKit",
              "type": "string",
              "required": true
            }
          }
        }
      }
    }
  }
}

This shows the form with expanded items:
Screenshot 2024-11-27 at 2 11 36 PM

and collapsed items:
Screenshot 2024-11-27 at 2 11 50 PM

This functionality is offered out of the box and may be just a question of updating jsonFormOptions in homebridge-config-ui-x/ui/src/app/core/components/schema-form/schema-form.component.html - line: 5:

    [options]="jsonFormOptions"

and homebridge-config-ui-x/ui/src/app/core/components/schema-form/schema-form.component.ts - lines 19-25:

  public jsonFormOptions = {
    addSubmit: false,
    loadExternalAssets: false,
    returnEmptyFields: false,
    setSchemaDefaults: true,
    autocomplete: false,
  }

Per ajsf/projects/ajsf-material/src/lib/widgets/flex-layout-section.component.ts it is looking at options to see if expandable is provided:

      [class.expandable]="options?.expandable && !expanded"
      [class.expanded]="options?.expandable && expanded">

@justjam2013
Copy link
Contributor Author

See How to display accessory name in header field? as acceptable solution, although the section header would need to be dynamic.

Copy link

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions.

@github-actions github-actions bot added the stale label Dec 28, 2024
@justjam2013
Copy link
Contributor Author

Keeping this open

@justjam2013
Copy link
Contributor Author

Closing this, as the following is supported:

      "devices":{
        "type": "array",
        ...
        "items":{
          ...
          "expandable": true, 
          ...
        }
      }

@justjam2013
Copy link
Contributor Author

Just noticed that @donavanbecker pinned this item, so reopened.

@justjam2013
Copy link
Contributor Author

Expanding and collapsing is supported, but it would be nice to have the cool fold/expand and delete icons.

@justjam2013
Copy link
Contributor Author

Update

The following is supported:

      "devices":{
        "type": "array",
        ...
        "items":{
          ...
          "expandable": true, 
          ...
        }
      }

It does not have pretty icons, but the functionality to expand and collapse items is available:

Image

The headers are still an issue, as the titles cannot be dynamically generated from the config.schema.json.

I have opened a feature request ticket with ng-formworks to provide dynamic headers for type array like tabarrays have: Feature request - Give "array" access to item fields, like "tabarray"

@bwp91
Copy link
Contributor

bwp91 commented Jan 18, 2025

can you post a full example of a json schema for this and i will see if i can make the icons a bit prettier

@justjam2013
Copy link
Contributor Author

justjam2013 commented Jan 18, 2025

The config.schema.json for my plugin uses it for the accessories
https://github.com/justjam2013/homebridge-virtual-accessories/blob/latest/config.schema.json

However, I'm wondering if it might not be better to wait and see what changes happen with the feature request tickets I opened with the ng-formworks framework. As much as it would be cool for the UI to look as slick as the Accessory Plugin template, it would massively suck if the FR implementation negatively affected any part of the effort.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants