Skip to content

Releases: Nerwyn/android-tv-card

3.7.0 - Roku Keyboard Support

10 May 21:08
Compare
Choose a tag to compare

Roku Keyboard Support

Adds Roku support for all three keyboard modes.

  • keyboard_mode must be set to ROKU.
  • Seamless and bulk text are sent using the Roku remote entity, while global search uses the media player entity. Either the Roku remote or media player entity IDs can be provided as the remote ID, but in order to use both text input and global search the other ID must be included using the remote_id or media_player_id fields.
type: custom:android-tv-card
keyboard_mode: ROKU
keyboard_id: remote.roku
media_player_id: media_player.roku
rows:
  - - keyboard
    - textbox
    - search

Other Changes

  • Only render keyboard mode and ID templates on render rather than every time an event is fired.

NOTE: I do not have a Roku and this release was tested by users. If you run into issues with the Roku keyboard, please reach out on the community forum and the GitHub page.

Full Changelog: 3.6.1...3.7.0

3.6.1 - Popup Support, Tooltip Styles, Autofill Targets, and Row/Column IDs

24 Apr 02:17
Compare
Choose a tag to compare

Changes in 3.6.1

  • Fixed missing context from haptic event renderTemplate call.
  • Improvements to slider value when value attribute is media_position.
  • Fixed issue where slider animation interval was not clearing.
  • Slider entity ID is now cached after rendering.
  • Other refactors to avoid null value errors.

New Action - fire-dom-event

You can now fire DOM events as an action! This is useful for opening browser mod popup cards. See the README for a quick example and the browser mod documentation for more information.

More Tooltip Options #74

You can now customize the tooltips label, offset, transform function, and display using these slider CSS properties:

  • --tooltip-label, defaults to {{ VALUE }}.
    • VALUE corresponds to the current slider value.
  • --tooltip-offset, defaults to {{ OFFSET }}px.
    • OFFSET corresponds to the tooltip x offset from center in pixels.
  • --tooltip-transform, defaults to translateX(var(--tooltip-offset)).
  • --tooltip-display, defaults to initial.
    • Deprecated field tooltip will also set this property.

Autofill Remote and Media Player IDs in Service Calls #73

The media_player_id field has been restored and a new field autofill_entity_id has been added. If the latter is enabled, any service call actions that do not have a target ID (entity, device, or area) will have their entity ID fields autopopulated if their service call domains are remote or media_player and the corresponding remote_id or media_player_id fields are populated. media_player_id will also work as slider_id if the latter is not provided and autofill for kodi and denonavr domain service calls.

Row and Column IDs for Card-Mod Styling #63

All rows and columns now have a unique ID that can be used for styling using card-mod. See this comment for an example.

Other Changes

  • Even more slider performance and render improvements.
  • Sliders will now properly update if their value is changed by something else after the user has touched them.
  • VALUE and HOLD_SECS can be used in most templates that do not apply to the root remote element.
  • Deprecated tooltip in favor of style options.
  • Change the amount of time slider waits before allowing for value updates from Home Assistant after using it using value_from_hass_delay (defaults to 1000ms).
  • Slider will update once per second if it's value attribute is media_position.
  • Keyboard buttons should no longer erroneously trigger and error due to regular button action handlers.

Patch Version Changes

  • Fixed missing context from haptic event renderTemplate call.
  • Improvements to slider value when value attribute is media_position.
  • Fixed issue where slider animation interval was not clearing.
  • Slider entity ID is now cached after rendering.
  • Other refactors to avoid null value errors.

Full Changelog: 3.5.2...3.6.1

3.6.0 - Popup Support, Tooltip Styles, Autofill Targets, and Row/Column IDs

22 Apr 15:35
Compare
Choose a tag to compare

New Action - fire-dom-event

You can now fire DOM events as an action! This is useful for opening browser mod popup cards. See the README for a quick example and the browser mod documentation for more information.

More Tooltip Options #74

You can now customize the tooltips label, offset, transform function, and display using these slider CSS properties:

  • --tooltip-label, defaults to {{ VALUE }}.
    • VALUE corresponds to the current slider value.
  • --tooltip-offset, defaults to {{ OFFSET }}px.
    • OFFSET corresponds to the tooltip x offset from center in pixels.
  • --tooltip-transform, defaults to translateX(var(--tooltip-offset)).
  • --tooltip-display, defaults to initial.
    • Deprecated field tooltip will also set this property.

Autofill Remote and Media Player IDs in Service Calls #73

The media_player_id field has been restored and a new field autofill_entity_id has been added. If the latter is enabled, any service call actions that do not have a target ID (entity, device, or area) will have their entity ID fields autopopulated if their service call domains are remote or media_player and the corresponding remote_id or media_player_id fields are populated. media_player_id will also work as slider_id if the latter is not provided and autofill for kodi and denonavr domain service calls.

Row and Column IDs for Card-Mod Styling #63

All rows and columns now have a unique ID that can be used for styling using card-mod. See this comment for an example.

Other Changes

  • Even more slider performance and render improvements.
  • Sliders will now properly update if their value is changed by something else after the user has touched them.
  • VALUE and HOLD_SECS can be used in most templates that do not apply to the root remote element.
  • Deprecated tooltip in favor of style options.
  • Change the amount of time slider waits before allowing for value updates from Home Assistant after using it using value_from_hass_delay (defaults to 1000ms).
  • Slider will update once per second if it's value attribute is media_position.
  • Keyboard buttons should no longer erroneously trigger and error due to regular button action handlers.

Full Changelog: 3.5.2...3.6.0

3.5.2 - Slider Improvements

26 Mar 14:43
Compare
Choose a tag to compare

Changes in 3.5.2

  • Slider value_attribute can now use attributes that are arrays, like hs_color[0].
  • Service call data can now include VALUE and templates in array data.

Slider Tooltip

Sliders now show a tooltip with the current value when held down on, similar to Home Assistant tile sliders. You can disable this by setting tooltip to false in a custom action for the slider.

image

The slider has also been refactored so it should perform a bit better, and shouldn't prematurely update it's value right after it sends an action, causing it to rubber band between the old and new values. The logic for turning the slider on and off has also been improved so it should update faster.

As part of standardizing the slider in this project with my other custom tile feature project, some slider related fields have been deprecated and moved to a slider custom action (old remote configs should continue to work).

  • slider_range -> custom_actions.slider.range.
  • slider_style -> custom_actions.slider.style.
  • slider_attribute -> custom_actions.slider.value_attribute.
  • enable_slider_feedback -> custom_actions.slider.haptics.

You can now also set the slider step value in a custom action for the slider.

Haptics

You can now enable or disable haptics for specific buttons by setting haptics to true or false within their custom actions.

The following fields have been renamed:

  • enable_button_feedback -> button_haptics .
  • enable_touchpad_feedback -> touchpad_haptics.
custom_actions:
  slider:
    range:
      - 0.5
      - 1
    step: 0.1
    value_attribute: brightness # defaults to volume_level
    tooltip: true # defaults to true so you don't really need this line
    haptics: false # defaults to true
    style:
      '--border-radius': 4px

Other Changes

  • Fixed slider ID logic bug which would cause multiple sliders in different copies of the same card to use the same slider ID or not work at all #67.
    • And another issue where default actions were being overwritten in one copy of this card and those changes showing up in another.

Patch Version Changes

  • Mouse and touch event handlers are now always added to the element to fix support on environments such as the MacOS Home Assistant app (which says it has touch event handlers even if the devices does not have a touch screen) and tablets with desktop browsers.
  • Prevent context menu from appearing when using touch hold actions on desktop browsers.
  • Prevent touchpad center action from firing at the end of a multi touch action.
  • Slider value_attribute can now use attributes that are arrays, like hs_color[0].
  • Service call data can now include VALUE and templates in array data.

Full Changelog: 3.4.0...3.5.2

3.5.1 - Slider Improvements

24 Mar 23:37
Compare
Choose a tag to compare

Changes in 3.5.1

  • Mouse and touch event handlers are now always added to the element to fix support on environments such as the MacOS Home Assistant app (which says it has touch event handlers even if the devices does not have a touch screen) and tablets with desktop browsers #70.
  • Prevent context menu from appearing when using touch hold actions on desktop browsers.
  • Prevent touchpad center action from firing at the end of a multi touch action.

Slider Tooltip

Sliders now show a tooltip with the current value when held down on, similar to Home Assistant tile sliders. You can disable this by setting tooltip to false in a custom action for the slider.

image

The slider has also been refactored so it should perform a bit better, and shouldn't prematurely update it's value right after it sends an action, causing it to rubber band between the old and new values. The logic for turning the slider on and off has also been improved so it should update faster.

As part of standardizing the slider in this project with my other custom tile feature project, some slider related fields have been deprecated and moved to a slider custom action (old remote configs should continue to work).

  • slider_range -> custom_actions.slider.range.
  • slider_style -> custom_actions.slider.style.
  • slider_attribute -> custom_actions.slider.value_attribute.
  • enable_slider_feedback -> custom_actions.slider.haptics.

You can now also set the slider step value in a custom action for the slider.

Haptics

You can now enable or disable haptics for specific buttons by setting haptics to true or false within their custom actions.

The following fields have been renamed:

  • enable_button_feedback -> button_haptics .
  • enable_touchpad_feedback -> touchpad_haptics.
custom_actions:
  slider:
    range:
      - 0.5
      - 1
    step: 0.1
    value_attribute: brightness # defaults to volume_level
    tooltip: true # defaults to true so you don't really need this line
    haptics: false # defaults to true
    style:
      '--border-radius': 4px

Other Changes

  • Fixed slider ID logic bug which would cause multiple sliders in different copies of the same card to use the same slider ID or not work at all #67.
    • And another issue where default actions were being overwritten in one copy of this card and those changes showing up in another.

Patch Version Changes

  • Mouse and touch event handlers are now always added to the element to fix support on environments such as the MacOS Home Assistant app (which says it has touch event handlers even if the devices does not have a touch screen) and tablets with desktop browsers.
  • Prevent context menu from appearing when using touch hold actions on desktop browsers.
  • Prevent touchpad center action from firing at the end of a multi touch action.

Full Changelog: 3.4.0...3.5.1

3.5.0 - Slider Improvements

13 Mar 23:27
Compare
Choose a tag to compare

Slider Tooltip

Sliders now show a tooltip with the current value when held down on, similar to Home Assistant tile sliders. You can disable this by setting tooltip to false in a custom action for the slider.

image

The slider has also been refactored so it should perform a bit better, and shouldn't prematurely update it's value right after it sends an action, causing it to rubber band between the old and new values. The logic for turning the slider on and off has also been improved so it should update faster.

As part of standardizing the slider in this project with my other custom tile feature project, some slider related fields have been deprecated and moved to a slider custom action (old remote configs should continue to work).

  • slider_range -> custom_actions.slider.range.
  • slider_style -> custom_actions.slider.style.
  • slider_attribute -> custom_actions.slider.value_attribute.
  • enable_slider_feedback -> custom_actions.slider.haptics.

You can now also set the slider step value in a custom action for the slider.

Haptics

You can now enable or disable haptics for specific buttons by setting haptics to true or false within their custom actions.

The following fields have been renamed:

  • enable_button_feedback -> button_haptics .
  • enable_touchpad_feedback -> touchpad_haptics.
custom_actions:
  slider:
    range:
      - 0.5
      - 1
    step: 0.1
    value_attribute: brightness # defaults to volume_level
    tooltip: true # defaults to true so you don't really need this line
    haptics: false # defaults to true
    style:
      '--border-radius': 4px

Other Changes

  • Fixed slider ID logic bug which would cause multiple sliders in different copies of the same card to use the same slider ID or not work at all #67.
    • And another issue where default actions were being overwritten in one copy of this card and those changes showing up in another.

Full Changelog: 3.4.0...3.5.0

3.4.0 - Momentary Buttons, Customizable Timings, and Fire TV Keyboard

26 Feb 00:36
Compare
Choose a tag to compare

Momentary Buttons #58

This release adds an alternate button operating mode, momentary buttons. While disabled by default for all buttons and the touchpad, it can be enabled by creating custom actions for any button or the touchpad center action using action types momentary_start_action and momentary_end_action.

momentary_start_action fires when the button is initially pressed down and momentary_end_action fires when the button is released. Configuring either of these and setting their action fields to anything except none (or if their templates resolve do not resolve to none) will disable the buttons tap, hold, and double tap actions completely.

You can use momentary button mode to include HOLD_SECS in the momentary_end_action service call data

custom_actions:
  momentary_light:
    icon: mdi:ceiling-light
    momentary_start_action:
      action: call-service
      service: light.turn_on
      data:
        entity_id: light.sunroom_ceiling
    momentary_end_action:
      action: call-service
      service: light.turn_off
      data:
        entity_id: light.sunroom_ceiling
  fast_forward:
    momentary_start_action:
      action: none
    momentary_end_action:
      action: call-service
      service: remote.send_command
      data:
        entity_id: remote.google_tv
        command: MEDIA_FAST_FORWARD
        hold_secs: HOLD_SECS

Customizable Timings #60

You can now customize the delay between repeats for repeated hold actions using repeat_delay (default 100ms), the amount of time you have to trigger a double tap action using double_tap_window (default 200ms), and the amount of time you need to hold down a button to trigger a hold action using hold_time (default 500ms).

Note: setting double_tap_window larger than (or too close to) hold_time may result in undesirable behavior. Make sure to adjust both accordingly! Also, increasing double_tap_window will delay single tap actions even further.

All three of these values can be set either globally in the config root, or for specific custom actions like so.

repeat_delay: 200
double_tap_window: 500
hold_time: 1000
custom_actions:
  volume_up:
    hold_action:
      action: repeat
      repeat_delay: 50
  center:
    double_tap_action:
      action: key
      key: BACK
      double_tap_window: 300
    hold_action:
      action: key
      key: MENU
      hold_time: 600

Fire TV Keyboard Mode #62

While Fire TV is a fork of Android (until Amazon switches to their own proprietary OS in the future) and works with the current Android TV ADB keyboard for alphanumeric keys, it does not work with the backspace, delete, and enter keys as they are currently being sent with the Android Remote TV API, which Fire TV does not support. You can now set keyboard_mode to FIRE TV to fix support for these keys and send them via ADB instead.

Other Changes

  • Fix some overlooked auto field setting code for multi actions.
  • Fix empty buttons not generating correctly.
  • Change touchpad and slider background colors to --primary-background-color, as the previous --secondary-background-color color gets overwritten by Home Assistant to the default theme value if set to a different color in a custom theme.
    • Not sure if this was a recent change in Home Assistant, and if it's a bug or desired behavior.

Full Changelog: 3.3.0...3.4.0

3.3.0 - Multi Touch and More Customizable Repeat on Hold

02 Feb 23:30
Compare
Choose a tag to compare

Multi Touch Touchpad Gestures

This release implements a long awaited feature request, multi touch touchpad gestures #13. Invoke multi finger tap and swipe gestures on the touchpad by creating custom actions on up, down, left, right, and center with action types multi_tap_action, multi_hold_action, and multi_double_tap_action.

custom_actions:
  up:
    multi_tap_action:
      action: key
      key: VOLUME_UP
  down:
    multi_tap_action:
      action: key
      key: VOLUME_DOWN
  left:
    multi_tap_action:
      action: key
      key: MEDIA_REWIND
  right:
    multi_tap_action:
      action: key
      key: MEDIA_FAST_FORWARD
  center:
    double_tap_action:
      action: key
      key: BACK
    multi_tap_action:
      action: call-service
      service: light.toggle
      target:
        entity_id: light.ceiling
    multi_hold_action:
      action: key
      key: HOME
    multi_double_tap_action:
      action: key
      key: MUTE

Repeat on Hold

Any button and touchpad tap actions can now be made repeatable by setting the hold_action action field to repeat. By default the following default actions repeat when held, whether they are buttons or part of the touchpad:

  • up
  • down
  • left
  • right
  • volume_up
  • volume_down
  • delete
  • forward_delete

Similarly, the the above actions can be made not to repeat when held by setting their hold_action to something else.

custom_actions:
  channel_up:
    hold_action:
      action: repeat
  channel_down:
    hold_action:
      action: repeat
  volume_up:
    # this remaps volume up hold to a different action instead of the default repeat
    hold_action:
      action: call-service
      service: media_player.volume_set
      data:
        entity_id: media_player.google_tv
        volume_level: 1
  volume_down:
    # this disables volume down from repeating when held
    hold_action:
      action: none

Other changes:

  • Improved touchpad swipe direction detection and decreased sensitivity.
  • Held swipe direction can now be changed mid swipe.
  • Slider render fixes.
  • Refactored how button and touchpad actions are called.
  • Changed vibration levels to be light for all tap actions, medium for all normal hold actions, and selection (extra light) for repeated hold actions.
  • Fix button styles so there is not black/blue background when using them.
  • Fix keyboard buttons behavior to not trigger regular button actions erroneously, to also have scroll blocking logic of regular buttons, and to also use the mouseup/touchend handlers instead of onClick

Full Changelog: 3.2.10...3.3.0

3.2.10 - Better Buttons With Home Assistant Actions

29 Jan 00:35
Compare
Choose a tag to compare

Changes in 3.2.10

  • Merge data, target, and service_data fields into data if any exist rather than on action type.

Do more with buttons!

This release is focused on improving buttons and custom actions. Custom actions now follow Home Assistant actions syntax, and supports most actions defined there along with the key and source actions from this card. Confirmations are also supported.

The following actions are supported:

  • key
  • source
  • call-service
  • navigate
  • url
  • assist
  • more-info
  • none

Buttons now support not only tap actions, but double tap and hold actions! Just like the touchpad center tap. The touchpad center double tap and hold actions are now configured in this way, and the old separate fields for enabling and remapping center taps have been deprecated. Also, double tap actions on buttons and the touchpad now work on iPhone!

custom_actions:
  light_color:
    icon: mdi:lightbulb{{ "-outline" if is_state("light.sunroom_ceiling", "off") }}
    style:
      color: rgb({{ state_attr("light.sunroom_ceiling", "rgb_color") }}
    tap_action:
      action: call-service
      service: light.turn_on
      data:
        entity_id: light.sunroom_ceiling
        color_name: red
    hold_action:
      action: call-service
      service: light.turn_on
      data:
        entity_id: light.sunroom_ceiling
        color_name: blue
    double_tap_action:
      action: call-service
      service: light.turn_on
      data:
        entity_id: light.sunroom_ceiling
        color_name: green

Other changes:

  • Remapped hold actions do not add hold_secs: 0.5 to remote.send_command service calls.
  • Deprecated options:
    • enable_double_click and double_click_keycode - touchpad double tap is now enabled and reassigned by creating a custom action for center and creating a double_tap_action.
    • long_click_keycode - now reassigned by creating a custom action for center and creating a hold_action.
    • custom_keys and custom_sources - are now just custom_actions.

Patch version changes:

  • Do not add hold_secs = 0.5 to data on custom hold call-service actions.
  • Use js-yaml to parse template results in rows array that are yaml strings so templating can be used to define multiple remote elements.
  • Sliders can now be used for any action.
  • Fixed url action to work better on mobile and to match Home Assistant frontend code.
  • Added assist and more-info actions.
  • Fix button mode icon.
  • Deprecate svg_path, use icon for icon packs, custom icons, and svg paths.
  • Users can now use default svg icons that come with this card for custom actions.
  • Fix icon so that templates can be used with non-pack icons.
  • Prevent button and slider actions when scrolling #50.
  • Update Apple TV example #51.
  • Further slider scrolling detection improvements.
  • Added missing Firefox slider styles.
  • Tweaked slider styles for better performance and customizability.
  • Support for older webviews that do not support the structuredClone function.
  • Merge data, target, and service_data fields into data if any exist rather than on action type.

Full Changelog: 3.1.3...3.2.10

3.2.9 - Better Buttons With Home Assistant Actions

28 Jan 20:54
Compare
Choose a tag to compare

Changes in 3.2.9

  • Also merge data, target, and service_data fields for more-info actions.
    • And do so after action is autofilled if empty.

Do more with buttons!

This release is focused on improving buttons and custom actions. Custom actions now follow Home Assistant actions syntax, and supports most actions defined there along with the key and source actions from this card. Confirmations are also supported.

The following actions are supported:

  • key
  • source
  • call-service
  • navigate
  • url
  • assist
  • more-info
  • none

Buttons now support not only tap actions, but double tap and hold actions! Just like the touchpad center tap. The touchpad center double tap and hold actions are now configured in this way, and the old separate fields for enabling and remapping center taps have been deprecated. Also, double tap actions on buttons and the touchpad now work on iPhone!

custom_actions:
  light_color:
    icon: mdi:lightbulb{{ "-outline" if is_state("light.sunroom_ceiling", "off") }}
    style:
      color: rgb({{ state_attr("light.sunroom_ceiling", "rgb_color") }}
    tap_action:
      action: call-service
      service: light.turn_on
      data:
        entity_id: light.sunroom_ceiling
        color_name: red
    hold_action:
      action: call-service
      service: light.turn_on
      data:
        entity_id: light.sunroom_ceiling
        color_name: blue
    double_tap_action:
      action: call-service
      service: light.turn_on
      data:
        entity_id: light.sunroom_ceiling
        color_name: green

Other changes:

  • Remapped hold actions do not add hold_secs: 0.5 to remote.send_command service calls.
  • Deprecated options:
    • enable_double_click and double_click_keycode - touchpad double tap is now enabled and reassigned by creating a custom action for center and creating a double_tap_action.
    • long_click_keycode - now reassigned by creating a custom action for center and creating a hold_action.
    • custom_keys and custom_sources - are now just custom_actions.

Patch version changes:

  • Do not add hold_secs = 0.5 to data on custom hold call-service actions.
  • Use js-yaml to parse template results in rows array that are yaml strings so templating can be used to define multiple remote elements.
  • Sliders can now be used for any action.
  • Fixed url action to work better on mobile and to match Home Assistant frontend code.
  • Added assist and more-info actions.
  • Fix button mode icon.
  • Deprecate svg_path, use icon for icon packs, custom icons, and svg paths.
  • Users can now use default svg icons that come with this card for custom actions.
  • Fix icon so that templates can be used with non-pack icons.
  • Prevent button and slider actions when scrolling #50.
  • Update Apple TV example #51.
  • Further slider scrolling detection improvements.
  • Added missing Firefox slider styles.
  • Tweaked slider styles for better performance and customizability.
  • Support for older webviews that do not support the structuredClone function.
  • Also merge data, target, and service_data fields for more-info actions.
    • And do so after action is autofilled if empty.

Full Changelog: 3.1.3...3.2.9