Files
vrclipboard-ime-gui/node_modules/@tauri-apps/api/menu/base.cjs
2025-06-05 20:20:53 +09:00

101 lines
3.6 KiB
JavaScript

'use strict';
var tslib_es6 = require('../external/tslib/tslib.es6.cjs');
var core = require('../core.cjs');
var image = require('../image.cjs');
// Copyright 2019-2024 Tauri Programme within The Commons Conservancy
// SPDX-License-Identifier: Apache-2.0
// SPDX-License-Identifier: MIT
var _MenuItemBase_id, _MenuItemBase_kind;
function injectChannel(i) {
var _a;
if ('items' in i) {
i.items = (_a = i.items) === null || _a === void 0 ? void 0 : _a.map((item) => 'rid' in item ? item : injectChannel(item));
}
else if ('action' in i && i.action) {
const handler = new core.Channel();
handler.onmessage = i.action;
delete i.action;
return { ...i, handler };
}
return i;
}
async function newMenu(kind, opts) {
const handler = new core.Channel();
if (opts && typeof opts === 'object') {
if ('action' in opts && opts.action) {
handler.onmessage = opts.action;
delete opts.action;
}
// about predefined menu item icon
if ('item' in opts
&& opts.item
&& typeof opts.item === 'object'
&& 'About' in opts.item
&& opts.item.About
&& typeof opts.item.About === 'object'
&& 'icon' in opts.item.About
&& opts.item.About.icon) {
opts.item.About.icon = image.transformImage(opts.item.About.icon);
}
// icon menu item icon
if ('icon' in opts && opts.icon) {
opts.icon = image.transformImage(opts.icon);
}
// submenu items
if ('items' in opts && opts.items) {
function prepareItem(i) {
var _a;
if ('rid' in i) {
return [i.rid, i.kind];
}
if ('item' in i && typeof i.item === 'object' && ((_a = i.item.About) === null || _a === void 0 ? void 0 : _a.icon)) {
i.item.About.icon = image.transformImage(i.item.About.icon);
}
if ('icon' in i && i.icon) {
i.icon = image.transformImage(i.icon);
}
if ('items' in i && i.items) {
// @ts-expect-error the `prepareItem` return doesn't exactly match
// this is fine, because the difference is in `[number, string]` variant
i.items = i.items.map(prepareItem);
}
return injectChannel(i);
}
// @ts-expect-error the `prepareItem` return doesn't exactly match
// this is fine, because the difference is in `[number, string]` variant
opts.items = opts.items.map(prepareItem);
}
}
return core.invoke('plugin:menu|new', {
kind,
options: opts,
handler
});
}
class MenuItemBase extends core.Resource {
/** The id of this item. */
get id() {
return tslib_es6.__classPrivateFieldGet(this, _MenuItemBase_id, "f");
}
/** @ignore */
get kind() {
return tslib_es6.__classPrivateFieldGet(this, _MenuItemBase_kind, "f");
}
/** @ignore */
constructor(rid, id, kind) {
super(rid);
/** @ignore */
_MenuItemBase_id.set(this, void 0);
/** @ignore */
_MenuItemBase_kind.set(this, void 0);
tslib_es6.__classPrivateFieldSet(this, _MenuItemBase_id, id, "f");
tslib_es6.__classPrivateFieldSet(this, _MenuItemBase_kind, kind, "f");
}
}
_MenuItemBase_id = new WeakMap(), _MenuItemBase_kind = new WeakMap();
exports.MenuItemBase = MenuItemBase;
exports.newMenu = newMenu;