Add reset button to my menu in settings
Bug: Issue 8375 Change-Id: Icb54c712e1bea6a625aca5e91c87207bf0dbd3b1
This commit is contained in:
parent
4934d22cda
commit
8f4dd28909
@ -334,11 +334,16 @@ limitations under the License.
|
||||
</fieldset>
|
||||
<h2 id="Menu" class$="[[_computeHeaderClass(_menuChanged)]]">Menu</h2>
|
||||
<fieldset id="menu">
|
||||
<gr-menu-editor menu-items="{{_localMenu}}"></gr-menu-editor>
|
||||
<gr-menu-editor
|
||||
menu-items="{{_localMenu}}"></gr-menu-editor>
|
||||
<gr-button
|
||||
id="saveMenu"
|
||||
on-tap="_handleSaveMenu"
|
||||
disabled="[[!_menuChanged]]">Save changes</gr-button>
|
||||
<gr-button
|
||||
id="resetMenu"
|
||||
link
|
||||
on-tap="_handleResetMenuButton">Reset</gr-button>
|
||||
</fieldset>
|
||||
<h2 id="ChangeTableColumns"
|
||||
class$="[[_computeHeaderClass(_changeTableChanged)]]">
|
||||
|
@ -162,7 +162,7 @@
|
||||
this.prefs = prefs;
|
||||
this._showNumber = !!prefs.legacycid_in_change_table;
|
||||
this._copyPrefs('_localPrefs', 'prefs');
|
||||
this._cloneMenu();
|
||||
this._cloneMenu(prefs.my);
|
||||
this._cloneChangeTableColumns();
|
||||
}));
|
||||
|
||||
@ -226,9 +226,9 @@
|
||||
}
|
||||
},
|
||||
|
||||
_cloneMenu() {
|
||||
_cloneMenu(prefs) {
|
||||
const menu = [];
|
||||
for (const item of this.prefs.my) {
|
||||
for (const item of prefs) {
|
||||
menu.push({
|
||||
name: item.name,
|
||||
url: item.url,
|
||||
@ -343,12 +343,20 @@
|
||||
|
||||
_handleSaveMenu() {
|
||||
this.set('prefs.my', this._localMenu);
|
||||
this._cloneMenu();
|
||||
this._cloneMenu(this.prefs.my);
|
||||
return this.$.restAPI.savePreferences(this.prefs).then(() => {
|
||||
this._menuChanged = false;
|
||||
});
|
||||
},
|
||||
|
||||
_handleResetMenuButton() {
|
||||
return this.$.restAPI.getDefaultPreferences().then(data => {
|
||||
if (data && data.my) {
|
||||
this._cloneMenu(data.my);
|
||||
}
|
||||
});
|
||||
},
|
||||
|
||||
_handleSaveWatchedProjects() {
|
||||
this.$.watchedProjectsEditor.save();
|
||||
},
|
||||
|
@ -407,6 +407,42 @@ limitations under the License.
|
||||
assert.isTrue(element.prefs.legacycid_in_change_table);
|
||||
});
|
||||
|
||||
test('reset menu item back to default', done => {
|
||||
const originalMenu = {
|
||||
my: [
|
||||
{url: '/first/url', name: 'first name', target: '_blank'},
|
||||
{url: '/second/url', name: 'second name', target: '_blank'},
|
||||
{url: '/third/url', name: 'third name', target: '_blank'},
|
||||
],
|
||||
};
|
||||
|
||||
stub('gr-rest-api-interface', {
|
||||
getDefaultPreferences() { return Promise.resolve(originalMenu); },
|
||||
});
|
||||
|
||||
const updatedMenu = [
|
||||
{url: '/first/url', name: 'first name', target: '_blank'},
|
||||
{url: '/second/url', name: 'second name', target: '_blank'},
|
||||
{url: '/third/url', name: 'third name', target: '_blank'},
|
||||
{url: '/fourth/url', name: 'fourth name', target: '_blank'},
|
||||
];
|
||||
|
||||
element.set('_localMenu', updatedMenu);
|
||||
|
||||
element._handleResetMenuButton().then(() => {
|
||||
assertMenusEqual(element._localMenu, originalMenu.my);
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
test('test that reset button is called', () => {
|
||||
const overlayOpen = sandbox.stub(element, '_handleResetMenuButton');
|
||||
|
||||
MockInteractions.tap(element.$.resetMenu);
|
||||
|
||||
assert.isTrue(overlayOpen.called);
|
||||
});
|
||||
|
||||
suite('_getFilterDocsLink', () => {
|
||||
test('with http: docs base URL', () => {
|
||||
const base = 'http://example.com/';
|
||||
|
@ -756,6 +756,10 @@
|
||||
});
|
||||
},
|
||||
|
||||
getDefaultPreferences() {
|
||||
return this._fetchSharedCacheURL('/config/server/preferences');
|
||||
},
|
||||
|
||||
getPreferences() {
|
||||
return this.getLoggedIn().then(loggedIn => {
|
||||
if (loggedIn) {
|
||||
|
Loading…
Reference in New Issue
Block a user