mirror of
https://gh.wpcy.net/https://github.com/discourse/discourse.git
synced 2026-05-14 17:54:35 +08:00
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>
60 lines
1.6 KiB
Text
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>
|
|
}
|