@tldraw/tlschema
Version:
tldraw infinite canvas SDK (schema).
124 lines (123 loc) • 3.69 kB
JavaScript
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var TLImageAsset_exports = {};
__export(TLImageAsset_exports, {
imageAssetMigrations: () => imageAssetMigrations,
imageAssetProps: () => imageAssetProps,
imageAssetValidator: () => imageAssetValidator,
imageAssetVersions: () => Versions
});
module.exports = __toCommonJS(TLImageAsset_exports);
var import_store = require("@tldraw/store");
var import_validate = require("@tldraw/validate");
var import_TLBaseAsset = require("./TLBaseAsset");
const imageAssetProps = {
w: import_validate.T.number,
h: import_validate.T.number,
name: import_validate.T.string,
isAnimated: import_validate.T.boolean,
mimeType: import_validate.T.string.nullable(),
src: import_validate.T.srcUrl.nullable(),
fileSize: import_validate.T.nonZeroNumber.optional(),
pixelRatio: import_validate.T.positiveNumber.optional()
};
const imageAssetValidator = (0, import_TLBaseAsset.createAssetValidator)(
"image",
import_validate.T.object(imageAssetProps)
);
const Versions = (0, import_store.createMigrationIds)("com.tldraw.asset.image", {
AddIsAnimated: 1,
RenameWidthHeight: 2,
MakeUrlsValid: 3,
AddFileSize: 4,
MakeFileSizeOptional: 5,
AddPixelRatio: 6
});
const imageAssetMigrations = (0, import_store.createRecordMigrationSequence)({
sequenceId: "com.tldraw.asset.image",
recordType: "asset",
filter: (asset) => asset.type === "image",
sequence: [
{
id: Versions.AddIsAnimated,
up: (asset) => {
asset.props.isAnimated = false;
},
down: (asset) => {
delete asset.props.isAnimated;
}
},
{
id: Versions.RenameWidthHeight,
up: (asset) => {
asset.props.w = asset.props.width;
asset.props.h = asset.props.height;
delete asset.props.width;
delete asset.props.height;
},
down: (asset) => {
asset.props.width = asset.props.w;
asset.props.height = asset.props.h;
delete asset.props.w;
delete asset.props.h;
}
},
{
id: Versions.MakeUrlsValid,
up: (asset) => {
if (!import_validate.T.srcUrl.isValid(asset.props.src)) {
asset.props.src = "";
}
},
down: (_asset) => {
}
},
{
id: Versions.AddFileSize,
up: (asset) => {
asset.props.fileSize = -1;
},
down: (asset) => {
delete asset.props.fileSize;
}
},
{
id: Versions.MakeFileSizeOptional,
up: (asset) => {
if (asset.props.fileSize === -1) {
asset.props.fileSize = void 0;
}
},
down: (asset) => {
if (asset.props.fileSize === void 0) {
asset.props.fileSize = -1;
}
}
},
{
id: Versions.AddPixelRatio,
up: (_asset) => {
},
down: (asset) => {
delete asset.props.pixelRatio;
}
}
]
});
//# sourceMappingURL=TLImageAsset.js.map