diff --git a/src/state-summary/state-card-content.html b/src/state-summary/state-card-content.html
index 6b3cab2e43..7bad25154e 100644
--- a/src/state-summary/state-card-content.html
+++ b/src/state-summary/state-card-content.html
@@ -2,6 +2,7 @@
+
diff --git a/src/state-summary/state-card-content.js b/src/state-summary/state-card-content.js
index f5a329f457..71416a2267 100644
--- a/src/state-summary/state-card-content.js
+++ b/src/state-summary/state-card-content.js
@@ -4,6 +4,7 @@ import stateCardType from '../util/state-card-type';
require('./state-card-configurator');
require('./state-card-display');
+require('./state-card-input_select');
require('./state-card-media_player');
require('./state-card-scene');
require('./state-card-rollershutter');
diff --git a/src/state-summary/state-card-input_select.html b/src/state-summary/state-card-input_select.html
new file mode 100644
index 0000000000..5a0a002de0
--- /dev/null
+++ b/src/state-summary/state-card-input_select.html
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ [[item]]
+
+
+
+
+
+
diff --git a/src/state-summary/state-card-input_select.js b/src/state-summary/state-card-input_select.js
new file mode 100644
index 0000000000..3f1c446e68
--- /dev/null
+++ b/src/state-summary/state-card-input_select.js
@@ -0,0 +1,40 @@
+import hass from '../util/home-assistant-js-instance';
+import Polymer from '../polymer';
+
+require('../components/state-info');
+
+const { serviceActions } = hass;
+
+export default new Polymer({
+ is: 'state-card-input_select',
+
+ properties: {
+ stateObj: {
+ type: Object,
+ },
+
+ selectedOption: {
+ type: String,
+ observer: 'selectedOptionChanged',
+ },
+ },
+
+ computeSelected(stateObj) {
+ return stateObj.attributes.options.indexOf(stateObj.state);
+ },
+
+ selectedOptionChanged(option) {
+ // Selected Option will transition to '' before transitioning to new value
+ if (option === '' || option === this.stateObj.state) {
+ return;
+ }
+ serviceActions.callService('input_select', 'select_option', {
+ option,
+ entity_id: this.stateObj.entityId,
+ });
+ },
+
+ stopPropagation(ev) {
+ ev.stopPropagation();
+ },
+});
diff --git a/src/util/state-card-type.js b/src/util/state-card-type.js
index a97fbf1253..9a1be50d4e 100644
--- a/src/util/state-card-type.js
+++ b/src/util/state-card-type.js
@@ -2,6 +2,7 @@ import canToggle from './can-toggle';
const DOMAINS_WITH_CARD = [
'configurator',
+ 'input_select',
'media_player',
'rollershutter',
'scene',