Files
gerrit/polygerrit-ui/app/elements/core/gr-navigation/gr-navigation.html
Kasper Nilsson 3c2e121c9d Add more fields to Gerrit.Nav.View and utilize in app
Previously, the app relied on string matching of the view tag names in
order to perform view-based actions (e.g. routing).

This change refactors those instances to utilise the Gerrit.Nav.View
enum.

Bug: Issue 6708
Change-Id: If0212fde93e0167e3207af19006beee1a602df60
2017-07-19 17:02:08 -07:00

235 lines
6.9 KiB
HTML

<!--
Copyright (C) 2017 The Android Open Source Project
Licensed 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.
-->
<script>
(function(window) {
'use strict';
// Navigation parameters object format:
//
// Each object has a `view` property with a value from Gerrit.Nav.View. The
// remaining properties depend on the value used for view.
//
// - Gerrit.Nav.View.CHANGE:
// - `changeNum`, required, String: the numeric ID of the change.
//
// - Gerrit.Nav.View.SEARCH:
// - `owner`, optional, String: the owner name.
// - `project`, optional, String: the project name.
// - `branch`, optional, String: the branch name.
// - `topic`, optional, String: the topic name.
// - `statuses`, optional, Array<String>: the list of change statuses to
// search for. If more than one is provided, the search will OR them
// together.
//
// - Gerrit.Nav.View.DIFF:
// - `changeNum`, required, String: the numeric ID of the change.
// - `path`, required, String: the filepath of the diff.
// - `patchNum`, required, Number, the patch for the right-hand-side of
// the diff.
// - `basePatchNum`, optional, Number, the patch for the left-hand-side
// of the diff. If `basePatchNum` is provided, then `patchNum` must
// also be provided.
window.Gerrit = window.Gerrit || {};
// Prevent redefinition.
if (window.Gerrit.hasOwnProperty('Nav')) { return; }
const uninitialized = () => {
console.warn('Use of uninitialized routing');
};
const PARENT_PATCHNUM = 'PARENT';
window.Gerrit.Nav = {
View: {
ADMIN: 'admin',
CHANGE: 'change',
AGREEMENTS: 'agreements',
DASHBOARD: 'dashboard',
DIFF: 'diff',
SEARCH: 'search',
SETTINGS: 'settings',
},
/** @type {Function} */
_navigate: uninitialized,
/** @type {Function} */
_generateUrl: uninitialized,
_checkPatchRange(patchNum, basePatchNum) {
if (basePatchNum && !patchNum) {
throw new Error('Cannot use base patch number without patch number.');
}
},
/**
* Setup router implementation.
* @param {Function} handleNavigate
* @param {Function} generateUrl
*/
setup(navigate, generateUrl) {
this._navigate = navigate;
this._generateUrl = generateUrl;
},
destroy() {
this._navigate = uninitialized;
this._generateUrl = uninitialized;
},
/**
* Generate a URL for the given route parameters.
* @param {Object} params
* @return {string}
*/
_getUrlFor(params) {
return this._generateUrl(params);
},
/**
* @param {string} project The name of the project.
* @return {string}
*/
getUrlForProject(project) {
return this._getUrlFor({
view: Gerrit.Nav.View.SEARCH,
project,
});
},
/**
* @param {string} branch The name of the branch.
* @param {string} project The name of the project.
* @param {string} status The status to search.
* @return {string}
*/
getUrlForBranch(branch, project, status) {
return this._getUrlFor({
view: Gerrit.Nav.View.SEARCH,
branch,
project,
statuses: [status],
});
},
/**
* @param {string} topic The name of the topic.
* @return {string}
*/
getUrlForTopic(topic) {
return this._getUrlFor({
view: Gerrit.Nav.View.SEARCH,
topic,
statuses: ['open', 'merged'],
});
},
/**
* @param {!Object} change The change object.
* @param {number} opt_patchNum
* @param {number|string} opt_basePatchNum The string 'PARENT' can be used
* for none.
* @return {string}
*/
getUrlForChange(change, opt_patchNum, opt_basePatchNum) {
if (opt_basePatchNum === PARENT_PATCHNUM) {
opt_basePatchNum = undefined;
}
this._checkPatchRange(opt_patchNum, opt_basePatchNum);
return this._getUrlFor({
view: Gerrit.Nav.View.CHANGE,
changeNum: change._number,
patchNum: opt_patchNum,
basePatchNum: opt_basePatchNum,
});
},
/**
* @param {!Object} change The change object.
* @param {number} opt_patchNum
* @param {number|string} opt_basePatchNum The string 'PARENT' can be used
* for none.
* @return {string}
*/
navigateToChange(change, opt_patchNum, opt_basePatchNum) {
this._navigate(this.getUrlForChange(change, opt_patchNum,
opt_basePatchNum));
},
/**
* @param {!Object} change The change object.
* @param {!String} path The file path.
* @param {number} opt_patchNum
* @param {number|string} opt_basePatchNum The string 'PARENT' can be used
* for none.
* @return {string}
*/
getUrlForDiff(change, path, opt_patchNum, opt_basePatchNum) {
if (opt_basePatchNum === PARENT_PATCHNUM) {
opt_basePatchNum = undefined;
}
this._checkPatchRange(opt_patchNum, opt_basePatchNum);
return this._getUrlFor({
view: Gerrit.Nav.View.DIFF,
changeNum: change._number,
path,
patchNum: opt_patchNum,
basePatchNum: opt_basePatchNum,
});
},
/**
* @param {!Object} change The change object.
* @param {!String} path The file path.
* @param {number} opt_patchNum
* @param {number|string} opt_basePatchNum The string 'PARENT' can be used
* for none.
*/
navigateToDiff(change, path, opt_patchNum, opt_basePatchNum) {
this._navigate(this.getUrlForDiff(change, path, opt_patchNum,
opt_basePatchNum));
},
/**
* @param {string} owner The name of the owner.
* @return {string}
*/
getUrlForOwner(owner) {
return this._getUrlFor({
view: Gerrit.Nav.View.SEARCH,
owner,
});
},
/**
* Navigate to an arbitrary relative URL.
* @param {!string} relativeUrl
*/
navigateToRelativeUrl(relativeUrl) {
if (!relativeUrl.startsWith('/')) {
throw new Error('navigateToRelativeUrl with non-relative URL');
}
this._navigate(relativeUrl);
},
};
})(window);
</script>