mirror of
https://github.com/barsdeveloper/ueblueprint.git
synced 2026-02-04 08:17:41 +08:00
51 lines
1.8 KiB
JavaScript
51 lines
1.8 KiB
JavaScript
import { html } from "lit"
|
|
import Utility from "../../Utility.js"
|
|
import RotatorEntity from "../../entity/RotatorEntity.js"
|
|
import INumericPinTemplate from "./INumericPinTemplate.js"
|
|
|
|
/** @extends INumericPinTemplate<RotatorEntity> */
|
|
export default class RotatorPinTemplate extends INumericPinTemplate {
|
|
|
|
#getR() {
|
|
return Utility.printNumber(this.element.getDefaultValue()?.R ?? 0)
|
|
}
|
|
|
|
#getP() {
|
|
return Utility.printNumber(this.element.getDefaultValue()?.P ?? 0)
|
|
}
|
|
|
|
#getY() {
|
|
return Utility.printNumber(this.element.getDefaultValue()?.Y ?? 0)
|
|
}
|
|
|
|
setDefaultValue(values = [], rawValues = values) {
|
|
const rotator = this.element.getDefaultValue(true)
|
|
if (!(rotator instanceof RotatorEntity)) {
|
|
throw new TypeError("Expected DefaultValue to be a RotatorEntity")
|
|
}
|
|
rotator.R = values[0] // Roll
|
|
rotator.P = values[1] // Pitch
|
|
rotator.Y = values[2] // Yaw
|
|
this.element.requestUpdate("DefaultValue", rotator)
|
|
}
|
|
|
|
renderInput() {
|
|
return html`
|
|
<div class="ueb-pin-input-wrapper">
|
|
<span class="ueb-pin-input-label">X</span>
|
|
<div class="ueb-pin-input">
|
|
<ueb-input .singleLine="${true}" .innerText="${this.#getR()}"></ueb-input>
|
|
</div>
|
|
<span class="ueb-pin-input-label">Y</span>
|
|
<div class="ueb-pin-input">
|
|
<ueb-input .singleLine="${true}" .innerText="${this.#getP()}"></ueb-input>
|
|
</div>
|
|
<span class="ueb-pin-input-label">Z</span>
|
|
<div class="ueb-pin-input">
|
|
<ueb-input .singleLine="${true}" .innerText="${this.#getY()}"></ueb-input>
|
|
</div>
|
|
</div>
|
|
`
|
|
}
|
|
}
|