Sidebar-Power.js 5.14 KB

(function () {
	// Adds Atlassian shapes
	// power label
	Sidebar.prototype.addPowerPalette = function () {
		const { COMPONENT_TYPE } = this.enumCellBasicAttribute
		const { DEFAULT } = this.enumComponentType
		const gn = 'mxgraph.power';
		const dt = 'power';
		const label = '电源'
		const width = 66;
		const height = 74;
		const staticPath = `${Proxy_Prefix}/img/lib/thingskit/`
		const prefix = 'image;image=img/lib/thingskit/'
		const defaultStyle = ';imageAspect=0;'
		this.setCurrentSearchEntryLibrary(dt);

		// 自定义属性
		const cellAttribute = {
			[ COMPONENT_TYPE ]: DEFAULT
		}

		const graphPathLib = [
			{ name: '三相开关盒.svg', path: 'power/三相开关盒.svg' },
			{ name: '不间断电源.svg', path: 'power/不间断电源.svg' },
			{ name: '交流驱动.svg', path: 'power/交流驱动.svg' },
			{ name: '交流驱动2.svg', path: 'power/交流驱动2.svg' },
			{ name: '仪表.svg', path: 'power/仪表.svg' },
			{ name: '供热机组.svg', path: 'power/供热机组.svg' },
			{ name: '功率监控器.svg', path: 'power/功率监控器.svg' },
			{ name: '半导体控制整流器组装.svg', path: 'power/半导体控制整流器组装.svg' },
			{ name: '双线电线杆.svg', path: 'power/双线电线杆.svg' },
			{ name: '发电厂.svg', path: 'power/发电厂.svg' },
			{ name: '发电机.svg', path: 'power/发电机.svg' },
			{ name: '发电机2.svg', path: 'power/发电机2.svg' },
			{ name: '变压器.svg', path: 'power/变压器.svg' },
			{ name: '变压器监控器.svg', path: 'power/变压器监控器.svg' },
			{ name: '变压器组件.svg', path: 'power/变压器组件.svg' },
			{ name: '变速传动.svg', path: 'power/变速传动.svg' },
			{ name: '基座.svg', path: 'power/基座.svg' },
			{ name: '套管.svg', path: 'power/套管.svg' },
			{ name: '工业风力发电机 1.svg', path: 'power/工业风力发电机 1.svg' },
			{ name: '工业风力发电机 2.svg', path: 'power/工业风力发电机 2.svg' },
			{ name: '工业风力发电机 3.svg', path: 'power/工业风力发电机 3.svg' },
			{ name: '带电线的电线杆.svg', path: 'power/带电线的电线杆.svg' },
			{ name: '护具装置.svg', path: 'power/护具装置.svg' },
			{ name: '控制系统.svg', path: 'power/控制系统.svg' },
			{ name: '插座.svg', path: 'power/插座.svg' },
			{ name: '整流器 1.svg', path: 'power/整流器 1.svg' },
			{ name: '整流器 2.svg', path: 'power/整流器 2.svg' },
			{ name: '断路器.svg', path: 'power/断路器.svg' },
			{ name: '柴油发电机.svg', path: 'power/柴油发电机.svg' },
			{ name: '柴油支持UPS系统.svg', path: 'power/柴油支持UPS系统.svg' },
			{ name: '核反应堆.svg', path: 'power/核反应堆.svg' },
			{ name: '核电站.svg', path: 'power/核电站.svg' },
			{ name: '沼气发电.svg', path: 'power/沼气发电.svg' },
			{ name: '测温变阻器.svg', path: 'power/测温变阻器.svg' },
			{ name: '燃气轮机.svg', path: 'power/燃气轮机.svg' },
			{ name: '瓷绝缘体.svg', path: 'power/瓷绝缘体.svg' },
			{ name: '电子仪表.svg', path: 'power/电子仪表.svg' },
			{ name: '电涌放电器.svg', path: 'power/电涌放电器.svg' },
			{ name: '电源板.svg', path: 'power/电源板.svg' },
			{ name: '电线杆 1.svg', path: 'power/电线杆 1.svg' },
			{ name: '电线杆 2.svg', path: 'power/电线杆 2.svg' },
			{ name: '电线杆 3.svg', path: 'power/电线杆 3.svg' },
			{ name: '电线杆 4.svg', path: 'power/电线杆 4.svg' },
			{ name: '电线杆 5.svg', path: 'power/电线杆 5.svg' },
			{ name: '电缆分线箱.svg', path: 'power/电缆分线箱.svg' },
			{ name: '电解器.svg', path: 'power/电解器.svg' },
			{ name: '直流电源.svg', path: 'power/直流电源.svg' },
			{ name: '真空开关.svg', path: 'power/真空开关.svg' },
			{ name: '简易变电站.svg', path: 'power/简易变电站.svg' },
			{ name: '绝缘体.svg', path: 'power/绝缘体.svg' },
			{ name: '起动机.svg', path: 'power/起动机.svg' },
			{ name: '车用蓄电池.svg', path: 'power/车用蓄电池.svg' },
			{ name: '输电塔.svg', path: 'power/输电塔.svg' },
			{ name: '重合器 2.svg', path: 'power/重合器 2.svg' },
			{ name: '重合器.svg', path: 'power/重合器.svg' },
			{ name: '集中太阳能发电厂 1.svg', path: 'power/集中太阳能发电厂 1.svg' },
			{ name: '集中太阳能发电厂 2.svg', path: 'power/集中太阳能发电厂 2.svg' },
			{ name: '马达驱动.svg', path: 'power/马达驱动.svg' },
		]

		const lib = graphPathLib.map(item => {
			item.staticPath = staticPath + item.path
			return item
		})

		const fns = graphPathLib.map(item => {
			return this.addEntry(this.getTagsForStencil(gn, item.name, dt).join(' '), mxUtils.bind(this, function () {
				const cell = new mxCell('', new mxGeometry(0, 0, width, height), `${ prefix }${ item.path }${ defaultStyle }`);
				cell.setVertex(true)
				this.setCellAttributes(cell, cellAttribute)
				return this.createVertexTemplateFromCells([ cell ], cell.geometry.width, cell.geometry.height, item.name);
			}));
		})

		this.setVariableImageLib(dt, label, lib)

		this.addPaletteFunctions(dt, label, false, fns);

		this.setCurrentSearchEntryLibrary();
	};
})();