Convert `api.ts`, `api-implementation.ts` and `frames.ts` to ES6 modules (#5283)

This fixes ESLint errors in these files.

Set the `resolveJsonModule` setting, so that TypeScript can recognize the
`package.json` import.
main
Roman Donchenko 3 years ago committed by GitHub
parent 5dd7eff97a
commit c86746c785
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -3,31 +3,30 @@
//
// SPDX-License-Identifier: MIT
const config = require('./config').default;
import config from './config';
(() => {
const PluginRegistry = require('./plugins').default;
const serverProxy = require('./server-proxy').default;
const lambdaManager = require('./lambda-manager').default;
const {
import PluginRegistry from './plugins';
import serverProxy from './server-proxy';
import lambdaManager from './lambda-manager';
import {
isBoolean,
isInteger,
isString,
checkFilter,
checkExclusiveFields,
checkObjectType,
} = require('./common');
const User = require('./user').default;
const { AnnotationFormats } = require('./annotation-formats');
const { ArgumentError } = require('./exceptions');
const { Task, Job } = require('./session');
const Project = require('./project').default;
const CloudStorage = require('./cloud-storage').default;
const Organization = require('./organization').default;
const Webhook = require('./webhook').default;
function implementAPI(cvat) {
} from './common';
import User from './user';
import { AnnotationFormats } from './annotation-formats';
import { ArgumentError } from './exceptions';
import { Task, Job } from './session';
import Project from './project';
import CloudStorage from './cloud-storage';
import Organization from './organization';
import Webhook from './webhook';
export default function implementAPI(cvat) {
cvat.plugins.list.implementation = PluginRegistry.list;
cvat.plugins.register.implementation = PluginRegistry.register.bind(cvat);
@ -325,7 +324,4 @@ const config = require('./config').default;
};
return cvat;
}
module.exports = implementAPI;
})();
}

@ -8,34 +8,36 @@
* @module API
*/
function build() {
const PluginRegistry = require('./plugins').default;
const loggerStorage = require('./logger-storage').default;
const { Log } = require('./log');
const ObjectState = require('./object-state').default;
const Statistics = require('./statistics').default;
const Comment = require('./comment').default;
const Issue = require('./issue').default;
const { Job, Task } = require('./session');
const Project = require('./project').default;
const implementProject = require('./project-implementation').default;
const { Attribute, Label } = require('./labels');
const MLModel = require('./ml-model').default;
const { FrameData } = require('./frames');
const CloudStorage = require('./cloud-storage').default;
const Organization = require('./organization').default;
const Webhook = require('./webhook').default;
import PluginRegistry from './plugins';
import loggerStorage from './logger-storage';
import { Log } from './log';
import ObjectState from './object-state';
import Statistics from './statistics';
import Comment from './comment';
import Issue from './issue';
import { Job, Task } from './session';
import Project from './project';
import implementProject from './project-implementation';
import { Attribute, Label } from './labels';
import MLModel from './ml-model';
import { FrameData } from './frames';
import CloudStorage from './cloud-storage';
import Organization from './organization';
import Webhook from './webhook';
const enums = require('./enums');
import * as enums from './enums';
const {
import {
Exception, ArgumentError, DataError, ScriptingError, PluginError, ServerError,
} = require('./exceptions');
} from './exceptions';
import User from './user';
import pjson from '../package.json';
import config from './config';
const User = require('./user').default;
const pjson = require('../package.json');
const config = require('./config').default;
import implementAPI from './api-implementation';
function build() {
/**
* API entrypoint
* @namespace cvat
@ -925,9 +927,8 @@ function build() {
cvat.cloudStorages = Object.freeze(cvat.cloudStorages);
cvat.organizations = Object.freeze(cvat.organizations);
const implementAPI = require('./api-implementation');
const implemented = Object.freeze(implementAPI(cvat));
return implemented;
}
module.exports = build();
export default build();

@ -3,22 +3,21 @@
//
// SPDX-License-Identifier: MIT
(() => {
const cvatData = require('cvat-data');
const PluginRegistry = require('./plugins').default;
const serverProxy = require('./server-proxy').default;
const { isBrowser, isNode } = require('browser-or-node');
const { Exception, ArgumentError, DataError } = require('./exceptions');
import * as cvatData from 'cvat-data';
import { isBrowser, isNode } from 'browser-or-node';
import PluginRegistry from './plugins';
import serverProxy from './server-proxy';
import { Exception, ArgumentError, DataError } from './exceptions';
// This is the frames storage
const frameDataCache = {};
// This is the frames storage
const frameDataCache = {};
/**
/**
* Class provides meta information about specific frame and frame itself
* @memberof module:API.cvat.classes
* @hideconstructor
*/
class FrameData {
export class FrameData {
constructor({
width,
height,
@ -169,9 +168,9 @@
set imageData(imageData) {
this._data.imageData = imageData;
}
}
}
FrameData.prototype.data.implementation = async function (onServerRequest) {
FrameData.prototype.data.implementation = async function (onServerRequest) {
return new Promise((resolve, reject) => {
const resolveWrapper = (data) => {
this._data = {
@ -383,9 +382,9 @@
});
}
});
};
};
function getFrameMeta(jobID, frame) {
function getFrameMeta(jobID, frame) {
const { meta, mode, startFrame } = frameDataCache[jobID];
let size = null;
if (mode === 'interpolation') {
@ -400,9 +399,9 @@
throw new DataError(`Invalid mode is specified ${mode}`);
}
return size;
}
}
class FrameBuffer {
class FrameBuffer {
constructor(size, chunkSize, stopFrame, jobID) {
this._size = size;
this._buffer = {};
@ -628,9 +627,9 @@
cachedFrames() {
return Object.keys(this._buffer).map((f) => +f);
}
}
}
async function getImageContext(jobID, frame) {
async function getImageContext(jobID, frame) {
return new Promise((resolve, reject) => {
serverProxy.frames
.getImageContext(jobID, frame)
@ -650,18 +649,18 @@
reject(error);
});
});
}
}
async function getContextImage(jobID, frame) {
export async function getContextImage(jobID, frame) {
if (frameDataCache[jobID].frameBuffer.isContextImageAvailable(frame)) {
return frameDataCache[jobID].frameBuffer.getContextImage(frame);
}
const response = getImageContext(jobID, frame);
frameDataCache[jobID].frameBuffer.addContextImage(frame, response);
return frameDataCache[jobID].frameBuffer.getContextImage(frame);
}
}
async function getPreview(taskID = null, jobID = null) {
export async function getPreview(taskID = null, jobID = null) {
return new Promise((resolve, reject) => {
// Just go to server and get preview (no any cache)
serverProxy.frames
@ -682,9 +681,9 @@
reject(error);
});
});
}
}
async function getFrame(
export async function getFrame(
jobID,
chunkSize,
chunkType,
@ -695,7 +694,7 @@
isPlaying,
step,
dimension,
) {
) {
if (!(jobID in frameDataCache)) {
const blockType = chunkType === 'video' ? cvatData.BlockType.MP4VIDEO : cvatData.BlockType.ARCHIVE;
const meta = await serverProxy.frames.getMeta('job', jobID);
@ -739,9 +738,9 @@
}
return frameDataCache[jobID].frameBuffer.require(frame, jobID, isPlaying, step);
}
}
async function getDeletedFrames(instanceType, id) {
export async function getDeletedFrames(instanceType, id) {
if (instanceType === 'job') {
const { meta } = frameDataCache[id];
return meta.deleted_frames;
@ -754,21 +753,21 @@
}
throw new Exception(`getDeletedFrames is not implemented for ${instanceType}`);
}
}
function deleteFrame(jobID, frame) {
export function deleteFrame(jobID, frame) {
const { meta } = frameDataCache[jobID];
meta.deleted_frames[frame] = true;
}
}
function restoreFrame(jobID, frame) {
export function restoreFrame(jobID, frame) {
const { meta } = frameDataCache[jobID];
if (frame in meta.deleted_frames) {
delete meta.deleted_frames[frame];
}
}
}
async function patchMeta(jobID) {
export async function patchMeta(jobID) {
const { meta } = frameDataCache[jobID];
const newMeta = await serverProxy.frames.saveMeta('job', jobID, {
deleted_frames: Object.keys(meta.deleted_frames),
@ -785,9 +784,9 @@
frameDataCache[jobID].meta = newMeta;
frameDataCache[jobID].meta.deleted_frames = prevDeletedFrames;
}
}
async function findNotDeletedFrame(jobID, frameFrom, frameTo, offset) {
export async function findNotDeletedFrame(jobID, frameFrom, frameTo, offset) {
let meta;
if (!frameDataCache[jobID]) {
meta = await serverProxy.frames.getMeta('job', jobID);
@ -810,9 +809,9 @@
}
return lastUndeletedFrame;
}
}
function getRanges(jobID) {
export function getRanges(jobID) {
if (!(jobID in frameDataCache)) {
return {
decoded: [],
@ -824,26 +823,11 @@
decoded: frameDataCache[jobID].provider.cachedFrames,
buffered: frameDataCache[jobID].frameBuffer.cachedFrames(),
};
}
}
function clear(jobID) {
export function clear(jobID) {
if (jobID in frameDataCache) {
frameDataCache[jobID].frameBuffer.clear();
delete frameDataCache[jobID];
}
}
module.exports = {
FrameData,
getFrame,
getDeletedFrames,
deleteFrame,
restoreFrame,
patchMeta,
getRanges,
getPreview,
clear,
findNotDeletedFrame,
getContextImage,
};
})();
}

@ -13,7 +13,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const serverProxy = require('../../src/server-proxy').default;
// Test cases

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const CloudStorage= require('../../src/cloud-storage').default;
const { cloudStoragesDummyData } = require('../mocks/dummy-data.mock');

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const { FrameData } = require('../../src/frames');

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const { Job } = require('../../src/session');

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
describe('Feature: set attributes for an object state', () => {
test('set a valid value', () => {

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
describe('Feature: dummy feature', () => {
test('dummy test', async () => {

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const Project = require('../../src/project').default;

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const { AnnotationFormats, Loader, Dumper } = require('../../src/annotation-formats');
// Test cases

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const { Task } = require('../../src/session');

@ -12,7 +12,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const User = require('../../src/user').default;

@ -11,7 +11,7 @@ jest.mock('../../src/server-proxy', () => {
});
// Initialize api
window.cvat = require('../../src/api');
window.cvat = require('../../src/api').default;
const Webhook = require('../../src/webhook').default;
const { webhooksDummyData, webhooksEventsDummyData } = require('../mocks/dummy-data.mock');

@ -8,6 +8,7 @@
"isolatedModules": true,
"noEmit": true,
"baseUrl": "src",
"resolveJsonModule": true,
},
"include": ["src/*.ts"]
}

Loading…
Cancel
Save