From c94dabdbccf9460eaeab7710a2c6e8c42954d4f5 Mon Sep 17 00:00:00 2001 From: maxwroc Date: Thu, 23 Apr 2020 14:47:14 +0100 Subject: [PATCH 1/6] Option to collapse long list --- README.md | 2 +- package.json | 2 +- src/battery-vm.ts | 6 +----- src/index.ts | 4 +++- src/styles.ts | 32 ++++++++++++++++++++++++++++++++ src/types.ts | 7 ++++--- src/utils.ts | 2 +- src/views.ts | 12 +++++++++++- 8 files changed, 54 insertions(+), 13 deletions(-) diff --git a/README.md b/README.md index 393dfb12..0ad14f28 100644 --- a/README.md +++ b/README.md @@ -145,7 +145,7 @@ Entity view is useful when you want to add battery status next to other sensors #### Disabling colors -When you put empty array in `color_thresholds` propertyyou can disable colors. +When you put empty array in `color_thresholds` property you can disable colors. ![image](https://user-images.githubusercontent.com/8268674/79975932-aa461500-8493-11ea-9947-f4513863ae53.png) diff --git a/package.json b/package.json index cdfc9341..825049e0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "battery-state-card", - "version": "0.9.0", + "version": "1.0.0", "description": "Battery State card for Home Assistant", "main": "dist/battery-state-card.js", "repository": { diff --git a/src/battery-vm.ts b/src/battery-vm.ts index 1ad55473..40fad540 100644 --- a/src/battery-vm.ts +++ b/src/battery-vm.ts @@ -55,7 +55,7 @@ class BatteryViewModel { */ get levelColor(): string { - if (this.isColorGradientValid(this.config.color_gradient)) { + if (this.config.color_gradient && this.isColorGradientValid(this.config.color_gradient)) { return getColorInterpolationForPercentage(this.config.color_gradient, this.level); } @@ -82,10 +82,6 @@ class BatteryViewModel { } private isColorGradientValid(color_gradient: string[]) { - if (!color_gradient) { - return false; - } - if (color_gradient.length < 2) { log("Value for 'color_gradient' should be an array with at least 2 colors."); return; diff --git a/src/index.ts b/src/index.ts index 2901a2bd..c4f76ad1 100644 --- a/src/index.ts +++ b/src/index.ts @@ -111,9 +111,11 @@ class BatteryStateCard extends LitElement { return views.battery(this.batteries[0]); } + const batteryViews = this.batteries.map(battery => views.battery(battery)); + return views.card( this.config.name || "Battery levels", - this.batteries.map(battery => views.battery(battery)) + this.config.collapse ? [ views.collapsableWrapper(batteryViews, this.config.collapse) ] : batteryViews ); } diff --git a/src/styles.ts b/src/styles.ts index d4c18786..fd99559e 100644 --- a/src/styles.ts +++ b/src/styles.ts @@ -14,6 +14,38 @@ const styles = css` border-radius: 50%; text-align: center; } + + +.expand { + display: none; +} +.expand + label { + display: block; + text-align: right; + cursor: pointer; +} +.expand + label > div { + display: inline-block; + transform: rotate(-90deg); + font-size: 26px; + height: 29px; + width: 29px; + text-align: center; +} +.expand + label > div, +.expand + label + div { + transition: 0.5s ease-in-out; +} +.expand:checked + label > div { + transform: rotate(-90deg) scaleX(-1); +} +.expand + label + div { + max-height: 0; + overflow: hidden; +} +.expand:checked + label + div { + max-height: 1000px; +} `; export default styles; \ No newline at end of file diff --git a/src/types.ts b/src/types.ts index 6288205f..f2348d31 100644 --- a/src/types.ts +++ b/src/types.ts @@ -2,7 +2,7 @@ interface IColorThreshold { value: number; - color: string; + color?: string; } export interface IBatteryEntity { @@ -10,15 +10,16 @@ export interface IBatteryEntity { name?: string; attribute?: string; multiplier?: number; - value_override: number; // dev purposes only + value_override?: number; // dev purposes only } export interface IAppearance { color_thresholds?: IColorThreshold[]; - color_gradient: string[] + color_gradient?: string[]; } export interface IBatteryStateCardConfig extends IBatteryEntity, IAppearance { entities: IBatteryEntity[]; sort_by_level?: "asc" | "desc"; + collapse?: number; } \ No newline at end of file diff --git a/src/utils.ts b/src/utils.ts index c683e34b..33302c20 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -1,6 +1,6 @@ console.info( - '%c BATTERY-STATE-CARD %c 0.9.0 ', + '%c BATTERY-STATE-CARD %c 1.0.0 ', 'color: white; background: forestgreen; font-weight: 700;', 'color: forestgreen; background: white; font-weight: 700;', ); diff --git a/src/views.ts b/src/views.ts index 8acc2a90..ec7278b5 100644 --- a/src/views.ts +++ b/src/views.ts @@ -35,4 +35,14 @@ export const card = (headerText: string, contents: string[]) => html` ${contents} -`; \ No newline at end of file +`; + +export const collapsableWrapper = (contents: string[], collapseAfter: number) => { + const elemId = "expander" + Math.random().toString().substr(2); + return html` + ${contents.slice(0, collapseAfter)} + + +
${contents.slice(collapseAfter)}
+ ` +}; \ No newline at end of file From 9ebfb25e33e6511db95f8357afd4f59e2dad80d9 Mon Sep 17 00:00:00 2001 From: maxwroc Date: Thu, 23 Apr 2020 16:22:26 +0100 Subject: [PATCH 2/6] Report correct card size when collapse option is present --- src/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/index.ts b/src/index.ts index c4f76ad1..6d50c589 100644 --- a/src/index.ts +++ b/src/index.ts @@ -124,7 +124,7 @@ class BatteryStateCard extends LitElement { * distribute all cards over the available columns. */ getCardSize() { - return this.batteries.length + 1; + return (this.config.collapse || this.batteries.length) + 1; } /** From a42491a083af87c1674d115d2c815d42bf7f3654 Mon Sep 17 00:00:00 2001 From: maxwroc Date: Thu, 23 Apr 2020 16:33:03 +0100 Subject: [PATCH 3/6] Info about stars --- README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/README.md b/README.md index 8f54eb8f..42ef97f8 100644 --- a/README.md +++ b/README.md @@ -204,6 +204,10 @@ Bundeled transpiled code will appear in `dist` directory. Note: there is "undocumented" `value_override` property on the [entity object](#entity-object) which you can use for testing. +## Do you like the card? + +No buy-me-a-beer option but if you do like the card please star it on [github](https://github.com/maxwroc/battery-state-card)! This is a great way to give feedback and motivate to continue working on it. Thanks! + ## License This project is under the [MIT license](https://github.com/maxwroc/battery-state-card/blob/master/LICENSE). \ No newline at end of file From f5613758f36a2a348e6033d7bb8c10225eb0f782 Mon Sep 17 00:00:00 2001 From: maxwroc Date: Thu, 23 Apr 2020 16:49:00 +0100 Subject: [PATCH 4/6] Info about sorting and collapsed view --- README.md | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/README.md b/README.md index 42ef97f8..36f3b0cc 100644 --- a/README.md +++ b/README.md @@ -17,6 +17,7 @@ Card code is very small - less than 10KB. It **doesn't** depend on external depe | entities | array(string \| [Entity](#entity-object)) | **(required)** | v0.9.0 | List of entities | name | string | `"Battery levels"` | v0.9.0 | Card title | sort_by_level | string | | v0.9.0 | Values: `asc`, `desc` +| collapse | number | | v1.0.0 | Number of entities to show. Rest will be available in expandable section ([example](#sorted-list-and-collapsed-view)) +[appearance options](#appearance-options) @@ -179,6 +180,23 @@ You can setup as well colors only for lower battery levels and leave the default - sensor.bedroom_switch_battery_level ``` +### Sorted list and collapsed view + +![ezgif com-resize](https://user-images.githubusercontent.com/8268674/80119122-31bd8200-8581-11ea-9221-aee943d0b1a0.gif) + +```yaml +- type: custom:battery-state-card + name: "Sorted list and collapsed view" + sort_by_level: "asc" + collapse: 4 + entities: + - sensor.bedroom_motion_battery_level + - sensor.bathroom_motion_battery_level + - sensor.bedroomtemp_battery_level + - sensor.bedroom_balcony_battery_level + - sensor.bedroom_switch_battery_level +``` + ## Installation Once added to [HACS](https://community.home-assistant.io/t/custom-component-hacs/121727) add the following to your lovelace configuration From 64273eaa09575984c6af5d1c875756fcef04f853 Mon Sep 17 00:00:00 2001 From: maxwroc Date: Thu, 23 Apr 2020 17:58:47 +0100 Subject: [PATCH 5/6] Adjust the returned card size for collapse option --- src/index.ts | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/src/index.ts b/src/index.ts index 6d50c589..d0599130 100644 --- a/src/index.ts +++ b/src/index.ts @@ -120,11 +120,21 @@ class BatteryStateCard extends LitElement { } /** - * Gets the height of your card. Home Assistant uses this to automatically - * distribute all cards over the available columns. + * Gets the height of your card. + * + * Home Assistant uses this to automatically distribute all cards over + * the available columns. One is equal 50px. */ getCardSize() { - return (this.config.collapse || this.batteries.length) + 1; + let size = this.batteries.length; + + if (this.config.collapse) { + // +1 to account the expand button + size = this.config.collapse + 1; + } + + // +1 to account header + return size + 1; } /** From b6b67129b93b91b2d7a5d07276824be022695956 Mon Sep 17 00:00:00 2001 From: maxwroc Date: Sun, 26 Apr 2020 17:16:36 +0100 Subject: [PATCH 6/6] Rephrase like-card section --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 36f3b0cc..e19d2384 100644 --- a/README.md +++ b/README.md @@ -224,7 +224,7 @@ Note: there is "undocumented" `value_override` property on the [entity object](# ## Do you like the card? -No buy-me-a-beer option but if you do like the card please star it on [github](https://github.com/maxwroc/battery-state-card)! This is a great way to give feedback and motivate to continue working on it. Thanks! +If you do like the card please star it on [github](https://github.com/maxwroc/battery-state-card)! This is a great way to give feedback and motivation boost for me to continue working on it. Thanks! ## License