discourse/app/assets/javascripts/admin/addon/components/changes-banner.gjs
dependabot[bot] e7d3c344d1
Build(deps-dev): Bump the lint group across 1 directory with 4 updates (#33881)
Bumps the lint group with 4 updates in the / directory:
[@discourse/lint-configs](https://github.com/discourse/lint-configs),
[ember-template-lint](https://github.com/ember-template-lint/ember-template-lint),
[eslint](https://github.com/eslint/eslint) and
[stylelint](https://github.com/stylelint/stylelint).


Updates `@discourse/lint-configs` from 2.22.0 to 2.28.0
- [Commits](https://github.com/discourse/lint-configs/commits)

Updates `ember-template-lint` from 7.7.0 to 7.9.1
- [Release
notes](https://github.com/ember-template-lint/ember-template-lint/releases)
-
[Changelog](https://github.com/ember-template-lint/ember-template-lint/blob/master/CHANGELOG.md)
-
[Commits](https://github.com/ember-template-lint/ember-template-lint/commits)

Updates `eslint` from 9.27.0 to 9.32.0
- [Release notes](https://github.com/eslint/eslint/releases)
- [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md)
- [Commits](https://github.com/eslint/eslint/compare/v9.27.0...v9.32.0)

Updates `stylelint` from 16.19.1 to 16.22.0
- [Release notes](https://github.com/stylelint/stylelint/releases)
-
[Changelog](https://github.com/stylelint/stylelint/blob/main/CHANGELOG.md)
-
[Commits](https://github.com/stylelint/stylelint/compare/16.19.1...16.22.0)

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Discourse CI <ci@ci.invalid>
Co-authored-by: Jarek Radosz <jarek@cvx.dev>
2025-07-28 18:02:41 +02:00

60 lines
1.6 KiB
Text

import Component from "@glimmer/component";
import { tracked } from "@glimmer/tracking";
import { action } from "@ember/object";
import { htmlSafe } from "@ember/template";
import { modifier } from "ember-modifier";
import DButton from "discourse/components/d-button";
export default class ChangesBanner extends Component {
@tracked isSaving = false;
resizerModifier = modifier((element) => {
const container = document.getElementById("main-container");
const resizer = () => this.positionBanner(container, element);
resizer();
window.addEventListener("resize", resizer);
return () => window.removeEventListener("resize", resizer);
});
@action
async save() {
this.isSaving = true;
try {
await this.args.save();
} finally {
this.isSaving = false;
}
}
positionBanner(container, element) {
if (container) {
const { width } = container.getBoundingClientRect();
element.style.width = `${width}px`;
}
}
<template>
<div class="admin-changes-banner" {{this.resizerModifier}}>
<span class="admin-changes-banner__main-label">{{htmlSafe
@bannerLabel
}}</span>
<div class="controls">
<DButton
class="btn-secondary btn-small"
@action={{@discard}}
@disabled={{this.isSaving}}
@translatedLabel={{@discardLabel}}
/>
<DButton
class="btn-primary btn-small"
@action={{this.save}}
@isLoading={{this.isSaving}}
@translatedLabel={{@saveLabel}}
/>
</div>
</div>
</template>
}