mirror of https://github.com/hashicorp/consul
ui: Change URI helper to a template based approach (#9344)
This moves our uri helper to use a the template renderer we already have for rendering URLs.pull/9357/head
parent
e0a4646768
commit
613be01f43
@ -1,18 +1,19 @@
|
||||
import { helper } from '@ember/component/helper';
|
||||
import { get } from '@ember/object';
|
||||
import Helper from '@ember/component/helper';
|
||||
import { inject as service } from '@ember/service';
|
||||
|
||||
// Covers alpha-capitalized dot separated API keys such as
|
||||
// `{{Name}}`, `{{Service.Name}}` etc. but not `{{}}`
|
||||
// simple mustache regexp `/{{item.Name}}/`
|
||||
const templateRe = /{{([A-Za-z.0-9_-]+)}}/g;
|
||||
export default helper(function renderTemplate([template, vars]) {
|
||||
if (typeof vars !== 'undefined' && typeof template !== 'undefined') {
|
||||
return template.replace(templateRe, function(match, group) {
|
||||
try {
|
||||
return encodeURIComponent(get(vars, group) || '');
|
||||
} catch (e) {
|
||||
return '';
|
||||
let render;
|
||||
export default class RenderTemplateHelper extends Helper {
|
||||
@service('encoder') encoder;
|
||||
constructor() {
|
||||
super(...arguments);
|
||||
if (typeof render !== 'function') {
|
||||
render = this.encoder.createRegExpEncoder(templateRe, encodeURIComponent, false);
|
||||
}
|
||||
});
|
||||
}
|
||||
return '';
|
||||
});
|
||||
|
||||
compute([template, vars]) {
|
||||
return render(template, vars);
|
||||
}
|
||||
}
|
||||
|
@ -1,10 +1,18 @@
|
||||
import Helper from '@ember/component/helper';
|
||||
import { inject as service } from '@ember/service';
|
||||
|
||||
const templateRe = /\${([A-Za-z.0-9_-]+)}/g;
|
||||
let render;
|
||||
export default class UriHelper extends Helper {
|
||||
@service('encoder') encoder;
|
||||
constructor() {
|
||||
super(...arguments);
|
||||
if (typeof render !== 'function') {
|
||||
render = this.encoder.createRegExpEncoder(templateRe, encodeURIComponent);
|
||||
}
|
||||
}
|
||||
|
||||
compute(params, hash) {
|
||||
return this.encoder.uriJoin(params);
|
||||
compute([template, vars]) {
|
||||
return render(template, vars);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in new issue