126 lines
3.0 KiB
Plaintext
126 lines
3.0 KiB
Plaintext
import Component from "@glimmer/component";
|
|
import { tracked } from "@glimmer/tracking";
|
|
import { on } from "@ember/modifier";
|
|
import { action } from "@ember/object";
|
|
import { allowOnlyNumericInput } from "discourse/lib/utilities";
|
|
import I18n from "discourse-i18n";
|
|
import ComboBox from "select-kit/components/combo-box";
|
|
|
|
const UNIT_KB = "kb";
|
|
const UNIT_MB = "mb";
|
|
const UNIT_GB = "gb";
|
|
|
|
export default class FileSizeInput extends Component {
|
|
@tracked unit;
|
|
|
|
constructor() {
|
|
super(...arguments);
|
|
|
|
const sizeInKB = this.args.sizeValueKB;
|
|
if (sizeInKB >= 1024 * 1024) {
|
|
this.unit = UNIT_GB;
|
|
} else if (sizeInKB >= 1024) {
|
|
this.unit = UNIT_MB;
|
|
} else {
|
|
this.unit = UNIT_KB;
|
|
}
|
|
}
|
|
|
|
get number() {
|
|
const sizeInKB = this.args.sizeValueKB;
|
|
if (!sizeInKB) {
|
|
return;
|
|
}
|
|
if (this.unit === UNIT_KB) {
|
|
return sizeInKB;
|
|
}
|
|
if (this.unit === UNIT_MB) {
|
|
return sizeInKB / 1024;
|
|
}
|
|
if (this.unit === UNIT_GB) {
|
|
return sizeInKB / 1024 / 1024;
|
|
}
|
|
}
|
|
|
|
@action
|
|
keyDown(event) {
|
|
allowOnlyNumericInput(event);
|
|
}
|
|
|
|
get dropdownOptions() {
|
|
return [
|
|
{ label: I18n.t("number.human.storage_units.units.kb"), value: UNIT_KB },
|
|
{ label: I18n.t("number.human.storage_units.units.mb"), value: UNIT_MB },
|
|
{ label: I18n.t("number.human.storage_units.units.gb"), value: UNIT_GB },
|
|
];
|
|
}
|
|
|
|
@action
|
|
handleFileSizeChange(event) {
|
|
const value = parseFloat(event.target.value);
|
|
|
|
if (isNaN(value)) {
|
|
this.args.onChangeSize();
|
|
return;
|
|
}
|
|
|
|
let sizeInKB;
|
|
switch (this.unit) {
|
|
case "kb":
|
|
sizeInKB = value;
|
|
break;
|
|
case "mb":
|
|
sizeInKB = value * 1024;
|
|
break;
|
|
case "gb":
|
|
sizeInKB = value * 1024 * 1024;
|
|
break;
|
|
}
|
|
|
|
this.args.onChangeSize(sizeInKB);
|
|
|
|
if (sizeInKB > this.args.max) {
|
|
this.args.setValidationMessage(
|
|
I18n.t("file_size_input.error.size_too_large", {
|
|
provided_file_size: I18n.toHumanSize(sizeInKB * 1024),
|
|
max_file_size: I18n.toHumanSize(this.args.max * 1024),
|
|
})
|
|
);
|
|
} else if (sizeInKB < this.args.min) {
|
|
this.args.setValidationMessage(
|
|
I18n.t("file_size_input.error.size_too_small", {
|
|
provided_file_size: I18n.toHumanSize(sizeInKB * 1024),
|
|
min_file_size: I18n.toHumanSize(this.args.min * 1024),
|
|
})
|
|
);
|
|
} else {
|
|
this.args.setValidationMessage(null);
|
|
}
|
|
}
|
|
|
|
@action
|
|
onFileSizeUnitChange(newUnit) {
|
|
this.unit = newUnit;
|
|
}
|
|
|
|
<template>
|
|
<div class="file-size-picker">
|
|
<input
|
|
class="file-size-input"
|
|
value={{this.number}}
|
|
type="number"
|
|
step="any"
|
|
{{on "input" this.handleFileSizeChange}}
|
|
{{on "keydown" this.keyDown}}
|
|
/>
|
|
<ComboBox
|
|
class="file-size-unit-selector"
|
|
@valueProperty="value"
|
|
@content={{this.dropdownOptions}}
|
|
@value={{this.unit}}
|
|
@onChange={{this.onFileSizeUnitChange}}
|
|
/>
|
|
</div>
|
|
</template>
|
|
}
|