diff --git a/src/core_plugins/kibana/public/dashboard/dashboard_app.html b/src/core_plugins/kibana/public/dashboard/dashboard_app.html
index 49521b3cc09d..053a4dc5ac57 100644
--- a/src/core_plugins/kibana/public/dashboard/dashboard_app.html
+++ b/src/core_plugins/kibana/public/dashboard/dashboard_app.html
@@ -51,7 +51,7 @@
- Click the Add button in the menu bar above to add a visualization to the dashboard.
If you haven't set up any visualizations yet, visit the Visualize app to create your first visualization.
+ Click the Add button in the menu bar above to add a visualization to the dashboard.
If you haven't set up any visualizations yet, visit the Visualize app to create your first visualization.
@@ -70,4 +70,4 @@
>
-
\ No newline at end of file
+
diff --git a/src/ui/public/kbn_top_nav/kbn_top_nav_controller.js b/src/ui/public/kbn_top_nav/kbn_top_nav_controller.js
index d6cc9752315e..689021980a30 100644
--- a/src/ui/public/kbn_top_nav/kbn_top_nav_controller.js
+++ b/src/ui/public/kbn_top_nav/kbn_top_nav_controller.js
@@ -17,7 +17,7 @@
* under the License.
*/
-import { capitalize, isArray, isFunction } from 'lodash';
+import { capitalize, isArray, isFunction, get } from 'lodash';
import chrome from '../chrome';
import filterTemplate from '../chrome/config/filter.html';
@@ -83,7 +83,8 @@ export function KbnTopNavControllerProvider($compile) {
if (menuItem.disableButton()) {
return false;
}
- menuItem.run(menuItem, this, event.target);
+ // event will be undefined when method is called from click
+ menuItem.run(menuItem, this, get(event, 'target'));
};
// apply the defaults to individual options
_applyOptDefault(opt = {}) {
diff --git a/test/functional/apps/dashboard/_empty_dashboard.js b/test/functional/apps/dashboard/_empty_dashboard.js
new file mode 100644
index 000000000000..36f57d48c510
--- /dev/null
+++ b/test/functional/apps/dashboard/_empty_dashboard.js
@@ -0,0 +1,50 @@
+/*
+ * Licensed to Elasticsearch B.V. under one or more contributor
+ * license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright
+ * ownership. Elasticsearch B.V. licenses this file to you under
+ * the Apache License, Version 2.0 (the "License"); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import expect from 'expect.js';
+
+export default function ({ getService, getPageObjects }) {
+ const testSubjects = getService('testSubjects');
+ const dashboardAddPanel = getService('dashboardAddPanel');
+ const PageObjects = getPageObjects(['dashboard']);
+
+ describe('empty dashboard', async () => {
+ before(async () => {
+ await PageObjects.dashboard.clickNewDashboard();
+ });
+
+ after(async () => {
+ await dashboardAddPanel.closeAddPanel();
+ await PageObjects.dashboard.gotoDashboardLandingPage();
+ });
+
+ it('should display add button', async () => {
+ const addButtonExists = await testSubjects.exists('emptyDashboardAddPanelButton');
+ expect(addButtonExists).to.be(true);
+ });
+
+ it('should open add panel when add button is clicked', async () => {
+ await testSubjects.click('emptyDashboardAddPanelButton');
+ const isAddPanelOpen = await dashboardAddPanel.isAddPanelOpen();
+ expect(isAddPanelOpen).to.be(true);
+ });
+
+ });
+}
+
diff --git a/test/functional/apps/dashboard/index.js b/test/functional/apps/dashboard/index.js
index 93b6fc88b1d8..dc4000c96bd9 100644
--- a/test/functional/apps/dashboard/index.js
+++ b/test/functional/apps/dashboard/index.js
@@ -42,6 +42,7 @@ export default function ({ getService, loadTestFile, getPageObjects }) {
// This has to be first since the other tests create some embeddables as side affects and our counting assumes
// a fresh index.
+ loadTestFile(require.resolve('./_empty_dashboard'));
loadTestFile(require.resolve('./_embeddable_rendering'));
loadTestFile(require.resolve('./_create_and_add_embeddables'));
loadTestFile(require.resolve('./_time_zones'));