2023-03-14 13:18:55 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) HashiCorp, Inc.
|
2023-08-11 13:12:13 +00:00
|
|
|
* SPDX-License-Identifier: BUSL-1.1
|
2023-03-14 13:18:55 +00:00
|
|
|
*/
|
|
|
|
|
2020-10-08 15:52:09 +00:00
|
|
|
import Component from '@glimmer/component';
|
|
|
|
import { tracked } from '@glimmer/tracking';
|
|
|
|
import { action } from '@ember/object';
|
2021-01-05 10:05:59 +00:00
|
|
|
import { inject as service } from '@ember/service';
|
2020-10-08 15:52:09 +00:00
|
|
|
|
|
|
|
export default class TopoloyMetricsDownLines extends Component {
|
|
|
|
@tracked iconPositions;
|
2021-01-05 10:05:59 +00:00
|
|
|
@service('dom') dom;
|
|
|
|
|
|
|
|
get guid() {
|
|
|
|
return this.dom.guid(this);
|
|
|
|
}
|
2020-10-08 15:52:09 +00:00
|
|
|
|
|
|
|
@action
|
|
|
|
getIconPositions() {
|
|
|
|
const view = this.args.view;
|
|
|
|
const lines = [...document.querySelectorAll('#downstream-lines path')];
|
|
|
|
|
2022-09-15 08:43:17 +00:00
|
|
|
this.iconPositions = lines.map((item) => {
|
2020-10-08 15:52:09 +00:00
|
|
|
const pathLen = parseFloat(item.getTotalLength());
|
|
|
|
const thirdLen = item.getPointAtLength(Math.ceil(pathLen / 3));
|
|
|
|
|
|
|
|
return {
|
|
|
|
id: item.id,
|
2020-12-02 09:43:34 +00:00
|
|
|
x: Math.round(thirdLen.x - view.x),
|
|
|
|
y: Math.round(thirdLen.y - view.y),
|
2020-10-08 15:52:09 +00:00
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|