Show at least one decimal digit

This commit is contained in:
barsdeveloper
2022-04-27 21:28:37 +02:00
parent df518ccd3c
commit db0e3d0801
7 changed files with 65 additions and 30 deletions

View File

@@ -5,7 +5,7 @@ import TypeInitialization from "./entity/TypeInitialization"
export default class Utility {
static sigmoid(x, curvature = 1.7) {
return 1 / (1 + (x / Math.pow(1 - x, -curvature)))
return 1 / (1 + (x / (1 - x) ** -curvature))
}
static clamp(val, min, max) {
@@ -16,6 +16,19 @@ export default class Utility {
return Number(getComputedStyle(element).getPropertyValue("--ueb-scale"))
}
/**
* @param {Number} num
* @param {Number} decimals
*/
static minDecimals(num, decimals = 1) {
const powered = num * 10 ** decimals
if (Math.abs(powered % 1) > Number.EPSILON) {
// More decimal digits than required
return num.toString()
}
return num.toFixed(decimals)
}
/**
* @param {Number[]} viewportLocation
* @param {HTMLElement} movementElement

View File

@@ -22,6 +22,7 @@ export default class IInputPinTemplate extends PinTemplate {
setup(pin) {
super.setup(pin)
if (this.input = pin.querySelector(".ueb-pin-input-content")) {
this.setInput(pin, pin.entity.DefaultValue)
let self = this
this.onFocusHandler = (e) => {
pin.blueprint.dispatchEditTextEvent(true)
@@ -29,7 +30,7 @@ export default class IInputPinTemplate extends PinTemplate {
this.onFocusOutHandler = (e) => {
e.preventDefault()
document.getSelection().removeAllRanges() // Deselect text inside the input
self.acceptInput(pin)
self.setInput(pin, this.getInput(pin))
pin.blueprint.dispatchEditTextEvent(false)
}
this.input.addEventListener("focus", this.onFocusHandler)
@@ -72,9 +73,13 @@ export default class IInputPinTemplate extends PinTemplate {
/**
* @param {PinElement} pin
* @param {String} value
*/
acceptInput(pin) {
setInput(pin, value) {
pin.entity.DefaultValue = this.getInput(pin)
pin.querySelector(".ueb-pin-input-content")
// @ts-expect-error
.innerText = Utility.decodeInputString(value)
}
/**
@@ -84,9 +89,7 @@ export default class IInputPinTemplate extends PinTemplate {
if (pin.isInput()) {
return html`
<div class="ueb-pin-input">
<div class="ueb-pin-input-content" role="textbox" contenteditable="true">
${Utility.decodeInputString(sanitizeText(pin.entity.getDefaultValue()))}
</div>
<div class="ueb-pin-input-content" role="textbox" contenteditable="true"></div>
</div>
`
}

View File

@@ -36,7 +36,7 @@ export default class NodeTemplate extends SelectableDraggableTemplate {
</div>
${node.entity.EnabledState.toString() == "DevelopmentOnly" ? html`
<div class="ueb-node-developmentonly">Development Only</div>
` : ""}
` : ""}
${node.entity.AdvancedPinDisplay ? html`
<div class="ueb-node-expansion">
<svg
@@ -48,7 +48,6 @@ export default class NodeTemplate extends SelectableDraggableTemplate {
viewBox="4 4 24 24"
>
<path
fill-rule="evenodd"
d="
M 16.003 18.626
l 7.081 -7.081

View File

@@ -1,5 +1,6 @@
// @ts-check
import Utility from "../Utility"
import IInputPinTemplate from "./IInputPinTemplate"
/**
@@ -8,14 +9,16 @@ import IInputPinTemplate from "./IInputPinTemplate"
export default class RealPinTemplate extends IInputPinTemplate {
/**
* @param {PinElement} pin
* @param {String} value
*/
acceptInput(pin) {
const value = parseFloat(this.getInput(pin))
pin.entity.DefaultValue = isNaN(value)
? pin.entity.AutogeneratedDefaultValue
: value.toString()
setInput(pin, value) {
let num = parseFloat(this.getInput(pin))
if (isNaN(num)) {
num = parseFloat(pin.entity.AutogeneratedDefaultValue)
}
value = Utility.minDecimals(num)
super.setInput(pin, value)
}
}