amis-rpc-design/node_modules/monaco-editor/esm/vs/base/common/dataTransfer.js

139 lines
4.7 KiB
JavaScript
Raw Normal View History

2023-10-07 19:42:30 +08:00
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
import { distinct } from './arrays.js';
import { Iterable } from './iterator.js';
import { generateUuid } from './uuid.js';
export function createStringDataTransferItem(stringOrPromise) {
return {
asString: () => __awaiter(this, void 0, void 0, function* () { return stringOrPromise; }),
asFile: () => undefined,
value: typeof stringOrPromise === 'string' ? stringOrPromise : undefined,
};
}
export function createFileDataTransferItem(fileName, uri, data) {
const file = { id: generateUuid(), name: fileName, uri, data };
return {
asString: () => __awaiter(this, void 0, void 0, function* () { return ''; }),
asFile: () => file,
value: undefined,
};
}
export class VSDataTransfer {
constructor() {
this._entries = new Map();
}
get size() {
let size = 0;
for (const _ of this._entries) {
size++;
}
return size;
}
has(mimeType) {
return this._entries.has(this.toKey(mimeType));
}
matches(pattern) {
const mimes = [...this._entries.keys()];
if (Iterable.some(this, ([_, item]) => item.asFile())) {
mimes.push('files');
}
return matchesMimeType_normalized(normalizeMimeType(pattern), mimes);
}
get(mimeType) {
var _a;
return (_a = this._entries.get(this.toKey(mimeType))) === null || _a === void 0 ? void 0 : _a[0];
}
/**
* Add a new entry to this data transfer.
*
* This does not replace existing entries for `mimeType`.
*/
append(mimeType, value) {
const existing = this._entries.get(mimeType);
if (existing) {
existing.push(value);
}
else {
this._entries.set(this.toKey(mimeType), [value]);
}
}
/**
* Set the entry for a given mime type.
*
* This replaces all existing entries for `mimeType`.
*/
replace(mimeType, value) {
this._entries.set(this.toKey(mimeType), [value]);
}
/**
* Remove all entries for `mimeType`.
*/
delete(mimeType) {
this._entries.delete(this.toKey(mimeType));
}
/**
* Iterate over all `[mime, item]` pairs in this data transfer.
*
* There may be multiple entries for each mime type.
*/
*[Symbol.iterator]() {
for (const [mine, items] of this._entries) {
for (const item of items) {
yield [mine, item];
}
}
}
toKey(mimeType) {
return normalizeMimeType(mimeType);
}
}
function normalizeMimeType(mimeType) {
return mimeType.toLowerCase();
}
export function matchesMimeType(pattern, mimeTypes) {
return matchesMimeType_normalized(normalizeMimeType(pattern), mimeTypes.map(normalizeMimeType));
}
function matchesMimeType_normalized(normalizedPattern, normalizedMimeTypes) {
// Anything wildcard
if (normalizedPattern === '*/*') {
return normalizedMimeTypes.length > 0;
}
// Exact match
if (normalizedMimeTypes.includes(normalizedPattern)) {
return true;
}
// Wildcard, such as `image/*`
const wildcard = normalizedPattern.match(/^([a-z]+)\/([a-z]+|\*)$/i);
if (!wildcard) {
return false;
}
const [_, type, subtype] = wildcard;
if (subtype === '*') {
return normalizedMimeTypes.some(mime => mime.startsWith(type + '/'));
}
return false;
}
export const UriList = Object.freeze({
// http://amundsen.com/hypermedia/urilist/
create: (entries) => {
return distinct(entries.map(x => x.toString())).join('\r\n');
},
split: (str) => {
return str.split('\r\n');
},
parse: (str) => {
return UriList.split(str).filter(value => !value.startsWith('#'));
}
});