Skip to content

Commit

Permalink
Merge branch 'dev' into v3-split-state-into-init_entity-and-state
Browse files Browse the repository at this point in the history
  • Loading branch information
RFDarter authored Oct 13, 2024
2 parents b7835f7 + 029029c commit e2a8b36
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 7 deletions.
4 changes: 3 additions & 1 deletion packages/v3/src/css/tab.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,11 @@ import { css } from "lit";
export default css`
.tab-header {
display: inline-flex;
min-height: 40px;
max-width:90%;
font-weight: 400;
padding-inline: 1.5em;
padding-top: 0.5em;
padding-bottom: 0.5em;
align-items: center;
border-radius: 12px 12px 0px 0px;
background-color: rgba(127, 127, 127, 0.3);
Expand Down
55 changes: 49 additions & 6 deletions packages/v3/src/esp-entity-table.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import "iconify-icon";
interface entityConfig {
unique_id: string;
sorting_weight: number;
sorting_group?: string;
domain: string;
id: string;
state: string;
Expand Down Expand Up @@ -50,6 +51,11 @@ interface entityConfig {
is_disabled_by_default?: boolean;
}

interface groupConfig {
name: string;
sorting_weight: number;
}

export const stateOn = "ON";
export const stateOff = "OFF";

Expand All @@ -70,6 +76,7 @@ export class EntityTable extends LitElement implements RestAction {

private _actionRenderer = new ActionRenderer();
private _basePath = getBasePath();
private groups: groupConfig[] = []
private static ENTITY_UNDEFINED = "States";
private static ENTITY_CATEGORIES = [
"Sensor and Control",
Expand Down Expand Up @@ -108,7 +115,6 @@ export class EntityTable extends LitElement implements RestAction {
} else {
this._unknown_state_events[data.id] = 1;
}

// ignore the first few events, maybe the esp will send a detail_all
// event soon
if (this._unknown_state_events[data.id] < 5) {
Expand Down Expand Up @@ -139,6 +145,33 @@ export class EntityTable extends LitElement implements RestAction {
}
}
});

window.source?.addEventListener("sorting_group", (e: Event) => {
const messageEvent = e as MessageEvent;
const data = JSON.parse(messageEvent.data);
const groupIndex = this.groups.findIndex((x) => x.name === data.name);
if (groupIndex === -1) {
let group = {
...data,
} as groupConfig;
this.groups.push(group);
this.groups.sort((a, b) => {
return a.sorting_weight < b.sorting_weight
? -1
: 1
});
}
});

this.groups = EntityTable.ENTITY_CATEGORIES.map((category, index) => ({
name: category,
sorting_weight: index
}));

this.groups.push({
name: EntityTable.ENTITY_UNDEFINED,
sorting_weight: -1
});
}

addEntity(data: any) {
Expand Down Expand Up @@ -213,24 +246,34 @@ export class EntityTable extends LitElement implements RestAction {
}

render() {
function groupBy(xs: Array<any>, key: string): Map<string, Array<any>> {
return xs.reduce(function (rv, x) {
const groupBy = (xs: Array<any>, key: string): Map<string, Array<any>> => {
const groupedMap = xs.reduce(function (rv, x) {
(
rv.get(x[key]) ||
(() => {
let tmp: Array<string> = [];
let tmp: Array<any> = [];
rv.set(x[key], tmp);
return tmp;
})()
).push(x);
return rv;
}, new Map<string, Array<any>>());

const sortedGroupedMap = new Map<string, Array<any>>();
for (const group of this.groups) {
const groupName = group.name;
if (groupedMap.has(groupName)) {
sortedGroupedMap.set(groupName, groupedMap.get(groupName) || []);
}
}

return sortedGroupedMap;
}

const entities = this.show_all
? this.entities
: this.entities.filter((elem) => !elem.is_disabled_by_default);
const grouped = groupBy(entities, "entity_category");
const grouped = groupBy(entities, "sorting_group");
const elems = Array.from(grouped, ([name, value]) => ({ name, value }));
return html`
<div>
Expand All @@ -240,7 +283,7 @@ export class EntityTable extends LitElement implements RestAction {
class="tab-header"
@dblclick="${this._handleTabHeaderDblClick}"
>
${EntityTable.ENTITY_CATEGORIES[parseInt(group.name)] ||
${group.name ||
EntityTable.ENTITY_UNDEFINED}
</div>
<div class="tab-container">
Expand Down

0 comments on commit e2a8b36

Please sign in to comment.