UI: update Ember to 3.28.6 (#16616)

---------

Co-authored-by: wenincode <tyler.wendlandt@hashicorp.com>
pull/16687/head
Valeriia Ruban 2023-03-20 15:41:47 -07:00 committed by GitHub
parent 7eb3dcb65f
commit d75f2ba5da
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
26 changed files with 2790 additions and 5498 deletions

View File

@ -43,7 +43,7 @@ references:
# When updating the Go version, remember to also update the versions in the
# workflows section for go-test-lib jobs.
go: &GOLANG_IMAGE docker.mirror.hashicorp.services/cimg/go:1.20.1
ember: &EMBER_IMAGE docker.mirror.hashicorp.services/circleci/node:14-browsers
ember: &EMBER_IMAGE docker.mirror.hashicorp.services/circleci/node:16-browsers
ubuntu: &UBUNTU_CI_IMAGE ubuntu-2004:202201-02
cache:
yarn: &YARN_CACHE_KEY consul-ui-v9-{{ checksum "ui/yarn.lock" }}

View File

@ -1,4 +1,4 @@
FROM docker.mirror.hashicorp.services/circleci/node:14-browsers
FROM docker.mirror.hashicorp.services/circleci/node:16-browsers
USER root

View File

@ -1 +1 @@
14
16

View File

@ -25,7 +25,6 @@ deps: clean
cd packages/consul-ui && \
$(MAKE) deps
# Build a distribution of the UI for Vercel previews.
# The distribution must be copied into the ui/ subfolder
# in order to mirror the go binary

View File

@ -24,6 +24,6 @@
"ember-basic-dropdown": "3.0.21"
},
"engines": {
"node": ">=10 <=14"
"node": ">=14 <=16"
}
}

View File

@ -49,17 +49,17 @@ module.exports = {
// node files
{
files: [
'.eslintrc.js',
'tailwind.config.js',
'.docfy-config.js',
'.prettierrc.js',
'.template-lintrc.js',
'ember-cli-build.js',
'testem.js',
'blueprints/*/index.js',
'config/**/*.js',
'lib/*/index.js',
'server/**/*.js',
'./tailwind.config.js',
'./.docfy-config.js',
'./.eslintrc.js',
'./.prettierrc.js',
'./.template-lintrc.js',
'./ember-cli-build.js',
'./testem.js',
'./blueprints/*/index.js',
'./config/**/*.js',
'./lib/*/index.js',
'./server/**/*.js',
],
parserOptions: {
sourceType: 'script',

View File

@ -35,7 +35,7 @@ export default class AuthDialog extends Component {
if (typeof prev !== 'undefined' && prev !== current) {
type = 'use';
}
this.args.onchange({ data: get(this, 'token'), type: type });
this.args.onchange({ data: this.token, type: type });
}
@action

View File

@ -22,7 +22,7 @@ export default Component.extend({
return !items.findBy('Name', term);
},
add: function (name, changeset, value) {
if (!(changeset.get(name) || []).includes(value) && value.isNew) {
if (!(changeset.get(name) || []).includes(value)) {
changeset.pushObject(name, value);
changeset.validate();
}

View File

@ -47,7 +47,7 @@ export default Component.extend({
changeset: computed('item', function () {
const changeset = this.change.changesetFor(name, this.item || this.repo.create());
if (changeset.isNew) {
if (changeset.isPristine) {
changeset.validate();
}
return changeset;

View File

@ -4,7 +4,7 @@
*/
import Component from '@ember/component';
import { get, set } from '@ember/object';
import { set } from '@ember/object';
import { inject as service } from '@ember/service';
export default Component.extend({
@ -31,7 +31,7 @@ export default Component.extend({
set(item, 'Value', this.encoder.execute(target.value));
break;
case 'additional':
parent = get(this, 'parent');
parent = this.parent;
set(item, 'Key', `${parent !== '/' ? parent : ''}${target.value}`);
break;
case 'json':

View File

@ -5,11 +5,9 @@
import Component from '@glimmer/component';
import { inject as service } from '@ember/service';
import { computed, get, action } from '@ember/object';
import { alias } from '@ember/object/computed';
import { computed, get, action, defineProperty } from '@ember/object';
import { alias, sort } from '@ember/object/computed';
import { tracked } from '@glimmer/tracking';
import { sort } from '@ember/object/computed';
import { defineProperty } from '@ember/object';
export default class DataCollectionComponent extends Component {
@service('filter') filter;

View File

@ -37,12 +37,6 @@ export default Component.extend(Slotted, {
this._super(...arguments);
set(this, 'hasError', this._isRegistered('error'));
},
willDestroyElement: function () {
this._super(...arguments);
if (get(this, 'data.isNew')) {
this.data.rollbackAttributes();
}
},
actions: {
setData: function (data) {
let changeset = data;

View File

@ -18,7 +18,7 @@ export default Component.extend(Slotted, {
didReceiveAttrs: function () {
this._super(...arguments);
if (typeof this.items !== 'undefined') {
this.actions.change.apply(this, [this.items]);
this.send('change', this.items);
}
},
didInsertElement: function () {

View File

@ -34,8 +34,8 @@ export default Component.extend(Slotted, {
this._super(...arguments);
this._cellLayout = this['cell-layout'] = new PercentageColumns(
get(this, 'items.length'),
get(this, 'columns'),
get(this, 'cellHeight')
this.columns,
this.cellHeight
);
const o = this;
this['cell-layout'].formatItemStyle = function (itemIndex) {
@ -51,14 +51,14 @@ export default Component.extend(Slotted, {
return {};
}
return {
height: get(this, 'height'),
height: this.height,
};
}),
actions: {
resize: function (e) {
// TODO: This top part is very similar to resize in tabular-collection
// see if it make sense to DRY out
const dom = get(this, 'dom');
const dom = this.dom;
const $footer = dom.element('footer[role="contentinfo"]');
if ($footer) {
const border = 1;
@ -74,7 +74,7 @@ export default Component.extend(Slotted, {
return this.dom.clickFirstAnchor(e, '.list-collection > ul > li');
},
change: function (index, e = {}) {
if (e.target.checked && index !== get(this, 'checked')) {
if (e.target.checked && index !== this.checked) {
set(this, 'checked', parseInt(index));
this.$row = this.dom.closest('li', e.target);
this.$row.style.zIndex = 1;

View File

@ -25,7 +25,7 @@ export default CollectionComponent.extend(Slotted, {
this.guid = this.dom.guid(this);
// TODO: The row height should auto calculate properly from the CSS
const o = this;
this['cell-layout'] = new Grid(get(this, 'width'), get(this, 'rowHeight'));
this['cell-layout'] = new Grid(this.width, this.rowHeight);
this['cell-layout'].formatItemStyle = function (itemIndex) {
let style = formatItemStyle.apply(this, arguments);
if (o.checked === itemIndex) {
@ -40,12 +40,12 @@ export default CollectionComponent.extend(Slotted, {
this.actions.resize.apply(this, [{ target: this.dom.viewport() }]);
},
style: computed('rowHeight', '_items', 'maxRows', 'maxHeight', function () {
const maxRows = get(this, 'rows');
let height = get(this, 'maxHeight');
const maxRows = this.rows;
let height = this.maxHeight;
if (maxRows) {
let rows = Math.max(3, get(this._items || [], 'length'));
rows = Math.min(maxRows, rows);
height = get(this, 'rowHeight') * rows + 29;
height = this.rowHeight * rows + 29;
}
return {
height: height,
@ -80,7 +80,7 @@ export default CollectionComponent.extend(Slotted, {
const height = e.target.innerHeight - space;
this.set('maxHeight', Math.max(0, height));
// TODO: The row height should auto calculate properly from the CSS
this['cell-layout'] = new Grid($appContent.clientWidth, get(this, 'rowHeight'));
this['cell-layout'] = new Grid($appContent.clientWidth, this.rowHeight);
const o = this;
this['cell-layout'].formatItemStyle = function (itemIndex) {
let style = formatItemStyle.apply(this, arguments);
@ -100,7 +100,7 @@ export default CollectionComponent.extend(Slotted, {
if (this.$tr) {
this.$tr.style.zIndex = null;
}
if (e.target && e.target.checked && index !== get(this, 'checked')) {
if (e.target && e.target.checked && index !== this.checked) {
set(this, 'checked', parseInt(index));
const target = e.target;
const $tr = this.dom.closest('tr', target);

View File

@ -5,11 +5,11 @@
import { runInDebug } from '@ember/debug';
import require from 'require';
import merge from 'deepmerge';
import assign from 'deepmerge';
const doc = document;
export const services = merge.all(
export const services = assign.all(
[...doc.querySelectorAll(`script[data-services]`)].map(($item) =>
JSON.parse($item.dataset[`services`])
)

View File

@ -3,8 +3,7 @@
* SPDX-License-Identifier: MPL-2.0
*/
import Model from 'ember-data/model';
import attr from 'ember-data/attr';
import Model, { attr } from '@ember-data/model';
export const PRIMARY_KEY = 'uid';
export const SLUG_KEY = 'Name';

View File

@ -31,6 +31,7 @@ export default class WithCopyableModifier extends Modifier {
this.source = this.clipboard
.execute(this.element, {
text: (_) => value,
container: this.element,
...hash.options,
})
.on('success', hash.success)

View File

@ -7,14 +7,14 @@
import EmberRouter from '@ember/routing/router';
import config from './config/environment';
import { runInDebug } from '@ember/debug';
import merge from 'deepmerge';
import assign from 'deepmerge';
import { env } from 'consul-ui/env';
import walk, { dump } from 'consul-ui/utils/routing/walk';
const doc = document;
const appName = config.modulePrefix;
export const routes = merge.all(
export const routes = assign.all(
[...doc.querySelectorAll(`script[data-routes]`)].map(($item) =>
JSON.parse($item.dataset[`routes`])
)

View File

@ -143,6 +143,6 @@ export default class BaseRoute extends Route {
if (typeof obj !== 'undefined' && !Array.isArray(obj) && typeof obj !== 'string') {
params = Object.values(obj);
}
return super.transitionTo(routeName, ...params);
return this.router.transitionTo(routeName, ...params);
}
}

View File

@ -14,24 +14,22 @@ export default class OAuth2CodeWithURLProvider extends OAuth2CodeProvider {
}
open(options) {
const name = this.get('name'),
const name = this.name,
url = this.buildUrl(),
responseParams = ['state', 'code'],
responseType = 'code';
return this.get('popup')
.open(url, responseParams, options)
.then(function (authData) {
// the same as the parent class but with an authorizationState added
const creds = {
authorizationState: authData.state,
authorizationCode: decodeURIComponent(authData[responseType]),
provider: name,
};
runInDebug((_) =>
console.info('Retrieved the following creds from the OAuth Provider', creds)
);
return creds;
});
return this.popup.open(url, responseParams, options).then(function (authData) {
// the same as the parent class but with an authorizationState added
const creds = {
authorizationState: authData.state,
authorizationCode: decodeURIComponent(authData[responseType]),
provider: name,
};
runInDebug((_) =>
console.info('Retrieved the following creds from the OAuth Provider', creds)
);
return creds;
});
}
close() {

View File

@ -9,13 +9,13 @@
<route.Announcer @title='Consul' />
{{! Tell CSS what we have enabled }}
{{#if (can 'use acls')}}
{{document-attrs class='has-acls'}}
{{document-attrs class="has-acls"}}
{{/if}}
{{#if (can 'use nspaces')}}
{{document-attrs class='has-nspaces'}}
{{document-attrs class="has-nspaces" }}
{{/if}}
{{#if (can 'use partitions')}}
{{document-attrs class='has-partitions'}}
{{document-attrs class="has-partitions" }}
{{/if}}
{{! Listen out for blocking query/client setting changes }}
@ -28,7 +28,7 @@
<DataSource @src={{uri 'settings://consul:theme'}} as |source|>
{{#each-in source.data as |key value|}}
{{#if (and value (includes key (array 'color-scheme' 'contrast')))}}
{{document-attrs class=(concat 'prefers-' key '-' value)}}
{{document-attrs class=(concat "prefers-" key "-" value) }}
{{/if}}
{{/each-in}}
</DataSource>

View File

@ -5,16 +5,16 @@
{{page-title 'Engineering Docs - Consul' separator=' - '}}
{{document-attrs class="is-debug"}}
{{document-attrs class="is-debug" }}
{{! Tell CSS what we have enabled }}
{{#if (can "use acls")}}
{{document-attrs class="has-acls"}}
{{document-attrs class="has-acls" }}
{{/if}}
{{#if (can "use nspaces")}}
{{document-attrs class="has-nspaces"}}
{{document-attrs class="has-nspaces" }}
{{/if}}
{{#if (can "use partitions")}}
{{document-attrs class="has-partitions"}}
{{document-attrs class="has-partitions" }}
{{/if}}
<App class="docs" id="wrapper">

View File

@ -3,7 +3,7 @@
"packages": [
{
"name": "ember-cli",
"version": "3.27.0",
"version": "3.28.6",
"blueprints": [
{
"name": "app",

View File

@ -64,7 +64,7 @@
"@docfy/ember": "^0.4.1",
"@ember/optional-features": "^2.0.0",
"@ember/render-modifiers": "^1.0.2",
"@ember/test-helpers": "^2.2.5",
"@ember/test-helpers": "^2.6.0",
"@glimmer/component": "^1.0.4",
"@glimmer/tracking": "^1.0.4",
"@hashicorp/design-system-components": "^1.6.0",
@ -87,7 +87,7 @@
"broccoli-funnel": "^3.0.3",
"broccoli-merge-trees": "^4.2.0",
"chalk": "^4.1.0",
"clipboard": "^2.0.4",
"clipboard": "^2.0.11",
"consul-acls": "*",
"consul-hcp": "*",
"consul-lock-sessions": "*",
@ -108,15 +108,15 @@
"ember-auto-import": "^2.4.2",
"ember-can": "^4.2.0",
"ember-changeset-validations": "~3.15.2",
"ember-cli": "~3.27.0",
"ember-cli": "3.28.6",
"ember-cli-app-version": "^5.0.0",
"ember-cli-babel": "^7.26.6",
"ember-cli-babel": "^7.26.10",
"ember-cli-code-coverage": "^1.0.0-beta.4",
"ember-cli-dependency-checker": "^3.2.0",
"ember-cli-deprecation-workflow": "^2.1.0",
"ember-cli-flash": "^2.1.1",
"ember-cli-htmlbars": "^5.7.1",
"ember-cli-inject-live-reload": "^2.0.2",
"ember-cli-htmlbars": "^5.7.2",
"ember-cli-inject-live-reload": "^2.1.0",
"ember-cli-page-object": "^1.17.11",
"ember-cli-postcss": "^8.1.0",
"ember-cli-sri": "^2.1.1",
@ -127,7 +127,7 @@
"ember-collection": "^1.0.0",
"ember-compatibility-helpers": "^1.2.5",
"ember-composable-helpers": "^5.0.0",
"ember-data": "~3.27.1",
"ember-data": "~3.28.6",
"ember-data-model-fragments": "5.0.0-beta.8",
"ember-decorators": "^6.1.1",
"ember-exam": "^6.1.0",
@ -145,25 +145,25 @@
"ember-page-title": "^6.2.2",
"ember-power-select": "^4.0.5",
"ember-power-select-with-create": "^0.8.0",
"ember-qunit": "^5.1.4",
"ember-qunit": "^5.1.5",
"ember-ref-bucket": "^4.1.0",
"ember-render-helpers": "^0.2.0",
"ember-resolver": "^8.0.2",
"ember-resolver": "^8.0.3",
"ember-route-action-helper": "^2.0.8",
"ember-router-helpers": "^0.4.0",
"ember-set-helper": "^2.0.0",
"ember-sinon-qunit": "5.0.0",
"ember-source": "~3.27.2",
"ember-source": "3.28.8",
"ember-stargate": "^0.2.0",
"ember-string-fns": "^1.4.0",
"ember-test-selectors": "^5.0.0",
"ember-truth-helpers": "^3.0.0",
"eslint": "^7.27.0",
"eslint": "^7.32.0",
"eslint-config-prettier": "^8.3.0",
"eslint-plugin-ember": "^10.4.2",
"eslint-plugin-ember": "^10.5.8",
"eslint-plugin-node": "^11.0.0",
"eslint-plugin-prettier": "^3.4.0",
"eslint-plugin-qunit": "^6.1.1",
"eslint-plugin-prettier": "^3.4.1",
"eslint-plugin-qunit": "^6.2.0",
"faker": "^5.5.3",
"flat": "^5.0.0",
"hast-util-to-string": "^1.0.4",
@ -177,9 +177,9 @@
"ngraph.graph": "^19.1.0",
"parse-duration": "^1.0.0",
"pretender": "^3.2.0",
"prettier": "^2.3.0",
"prettier": "^2.5.1",
"pretty-ms": "^7.0.1",
"qunit": "^2.15.0",
"qunit": "^2.17.2",
"qunit-dom": "^1.6.0",
"react-is": "^17.0.1",
"refractor": "^3.5.0",
@ -197,7 +197,7 @@
"webpack": "^5.74.0"
},
"engines": {
"node": ">=10 <=14"
"node": ">=14 <=16"
},
"ember": {
"edition": "octane"
@ -213,5 +213,8 @@
},
"volta": {
"node": "14.20.1"
},
"dependencies": {
"doctoc": "^2.0.0"
}
}

File diff suppressed because it is too large Load Diff