UNPKG

@tldraw/tlschema

Version:

A tiny little drawing app (schema).

112 lines (111 loc) 3.38 kB
"use strict"; 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 TLVideoAsset_exports = {}; __export(TLVideoAsset_exports, { videoAssetMigrations: () => videoAssetMigrations, videoAssetValidator: () => videoAssetValidator, videoAssetVersions: () => Versions }); module.exports = __toCommonJS(TLVideoAsset_exports); var import_store = require("@tldraw/store"); var import_validate = require("@tldraw/validate"); var import_TLBaseAsset = require("./TLBaseAsset"); const videoAssetValidator = (0, import_TLBaseAsset.createAssetValidator)( "video", import_validate.T.object({ 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.number.optional() }) ); const Versions = (0, import_store.createMigrationIds)("com.tldraw.asset.video", { AddIsAnimated: 1, RenameWidthHeight: 2, MakeUrlsValid: 3, AddFileSize: 4, MakeFileSizeOptional: 5 }); const videoAssetMigrations = (0, import_store.createRecordMigrationSequence)({ sequenceId: "com.tldraw.asset.video", recordType: "asset", filter: (asset) => asset.type === "video", 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; } } } ] }); //# sourceMappingURL=TLVideoAsset.js.map