2023-10-12 05:40:11 +02:00
|
|
|
// Copyright: Ankitects Pty Ltd and contributors
|
|
|
|
// License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
|
|
|
|
|
|
|
|
import { fabric } from "fabric";
|
|
|
|
|
2023-10-13 00:49:31 +02:00
|
|
|
import { TEXT_BACKGROUND_COLOR, TEXT_FONT_FAMILY, TEXT_PADDING } from "../tools/lib";
|
2023-10-12 05:40:11 +02:00
|
|
|
import type { ConstructorParams, Size } from "../types";
|
|
|
|
import type { ShapeDataForCloze } from "./base";
|
|
|
|
import { Shape } from "./base";
|
|
|
|
import { floatToDisplay } from "./floats";
|
|
|
|
import { xFromNormalized, xToNormalized, yFromNormalized, yToNormalized } from "./position";
|
|
|
|
|
|
|
|
export class Text extends Shape {
|
|
|
|
text: string;
|
|
|
|
scaleX: number;
|
|
|
|
scaleY: number;
|
|
|
|
|
|
|
|
constructor({
|
|
|
|
text = "",
|
|
|
|
scaleX = 1,
|
|
|
|
scaleY = 1,
|
|
|
|
...rest
|
|
|
|
}: ConstructorParams<Text> = {}) {
|
|
|
|
super(rest);
|
|
|
|
this.text = text;
|
|
|
|
this.scaleX = scaleX;
|
|
|
|
this.scaleY = scaleY;
|
|
|
|
}
|
|
|
|
|
|
|
|
toDataForCloze(): TextDataForCloze {
|
|
|
|
return {
|
|
|
|
...super.toDataForCloze(),
|
|
|
|
text: this.text,
|
|
|
|
// scaleX and scaleY are guaranteed to be equal since we lock the aspect ratio
|
|
|
|
scale: floatToDisplay(this.scaleX),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
toFabric(size: Size): fabric.IText {
|
2023-10-20 01:36:46 +02:00
|
|
|
const absolute = this.toAbsolute(size);
|
|
|
|
return new fabric.IText(absolute.text, {
|
|
|
|
...absolute,
|
2023-10-12 05:40:11 +02:00
|
|
|
fontFamily: TEXT_FONT_FAMILY,
|
2023-10-13 00:49:31 +02:00
|
|
|
backgroundColor: TEXT_BACKGROUND_COLOR,
|
2023-10-12 05:40:11 +02:00
|
|
|
padding: TEXT_PADDING,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-10-20 01:36:46 +02:00
|
|
|
toNormal(size: Size): Text {
|
|
|
|
return new Text({
|
|
|
|
...this,
|
|
|
|
...super.normalPosition(size),
|
|
|
|
scaleX: xToNormalized(size, this.scaleX),
|
|
|
|
scaleY: yToNormalized(size, this.scaleY),
|
|
|
|
});
|
2023-10-12 05:40:11 +02:00
|
|
|
}
|
|
|
|
|
2023-10-20 01:36:46 +02:00
|
|
|
toAbsolute(size: Size): Text {
|
|
|
|
return new Text({
|
|
|
|
...this,
|
|
|
|
...super.absolutePosition(size),
|
|
|
|
scaleX: xFromNormalized(size, this.scaleX),
|
|
|
|
scaleY: yFromNormalized(size, this.scaleY),
|
|
|
|
});
|
2023-10-12 05:40:11 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
interface TextDataForCloze extends ShapeDataForCloze {
|
|
|
|
text: string;
|
|
|
|
scale: string;
|
|
|
|
}
|