super-hero/extensions/shader-graph/dist/block-forge/pin.js

256 lines
24 KiB
JavaScript

'use strict';
Object.defineProperty(exports, "__esModule", { value: true });
exports.declarePin = exports.generateStyle = exports.generateInputPinHTML = exports.generateOutputPinHTML = exports.Pin = exports.PinAction = void 0;
const structures_1 = require("@itharbors/structures");
const TYPE = {};
class PinAction extends structures_1.Action {
// details: D & PinActionDetail;
constructor(pin, details) {
const cDetails = details;
cDetails.blockName = pin.pathData.blockName;
cDetails.index = pin.pathData.index;
super(cDetails);
// this.details = cDetails;
this.pin = pin;
}
exec(params) {
}
revertAction() {
return new PinAction(this.pin, {});
}
}
exports.PinAction = PinAction;
class Pin {
constructor() {
this.color = 'white';
this.line = '';
this.style = '';
this.pathData = {
blockName: '',
index: 0,
};
this.refs = {};
}
init(details, desc, blockName, index) {
this.details = details;
this.pathData.blockName = blockName;
this.pathData.index = index;
this.desc = desc;
}
exec(action) {
if (!this.$root) {
return;
}
const nodeRoot = this.$root.getRootNode();
if (nodeRoot) {
nodeRoot.host.dispatch('dirty', {
detail: {
action,
},
});
}
}
onInit() {
}
onUpdate() {
}
}
exports.Pin = Pin;
Pin.type = 'unknown';
// todo 考虑数据冲突
function generateIcon(pin) {
if (pin.icon) {
return /*html*/ `<ui-icon value="${pin.icon}"></ui-icon>`;
}
return '';
}
function generateTitle(pin) {
if (pin.name) {
return /*html*/ `<span class="name" title="${pin.name}">${pin.name}</span>`;
}
return '';
}
/**
* 生成 output pin 的 HTML
* @param pin
* @param details
* @returns
*/
function generateOutputPinHTML(pin, details) {
const type = pin.dataType;
const define = TYPE[type] || TYPE['unknown'];
const pinI = new define();
const color = pinI.color ? `--param-color: ${pinI.color};` : '';
const $pin = document.createElement('div');
$pin.classList.add('pin');
$pin.classList.add('out');
$pin.classList.add(type + '');
// @ts-ignore
$pin.__pin = pinI;
$pin.innerHTML = /*html*/ `${pinI.style ? `<style>${pinI.style}</style>` : ''}
<div class="body">
<div class="name">
${generateTitle(pin)}
${generateIcon(pin)}
</div>
</div>
<v-graph-node-param ${pin.hidePin ? 'hidden' : ''} style="${color}" class="point" direction="output" name="${pin.tag}" type="${type}" role="right"></v-graph-node-param>`;
const $refList = $pin.querySelectorAll('[ref]');
Array.prototype.forEach.call($refList, ($ref) => {
const ref = $ref.getAttribute('ref');
if (ref) {
pinI.refs[ref] = $ref;
}
});
pinI.details = details;
// pinI.onInit();
// pinI.onUpdate(details);
return $pin;
}
exports.generateOutputPinHTML = generateOutputPinHTML;
/**
* 生成 input pin 的 HTML
* @param pin
* @param pinData
* @param blockName
* @param lineMap
* @returns
*/
function generateInputPinHTML(pin, pinDataList, index, blockName, lineMap) {
const type = pin.dataType;
const define = TYPE[type] || TYPE['unknown'];
const pinI = new define();
const color = pinI.color ? `--param-color: ${pinI.color};` : '';
let connected = false;
for (const id in lineMap) {
const line = lineMap[id];
if (line &&
line.output.node === blockName &&
line.output.param === pin.tag) {
connected = true;
}
}
const $pin = document.createElement('div');
$pin.classList.add('pin');
$pin.classList.add('in');
$pin.classList.add(type + '');
// @ts-ignore
$pin.__pin = pinI;
$pin.innerHTML = /*html*/ `${pinI.style ? `<style>${pinI.style}</style>` : ''}
<div class="body">
<div class="name">
${generateIcon(pin)}
${generateTitle(pin)}
</div>
${pinI.contentSlot ? `<div class="slot-content" ${connected ? 'hidden' : ''}>${pinI.contentSlot}</div>` : ''}
</div>
${pinI.childrenSlot ? `<div class="children" ${connected ? 'hidden' : ''}>${pinI.childrenSlot.map(child => '<div class="slot-children">' + child + '</div>').join('')}</div>` : ''}
<v-graph-node-param ${pin.hidePin ? 'hidden' : ''} style="${color}" class="point" direction="input" name="${pin.tag}" type="${type}" role="left"></v-graph-node-param>`;
const $refList = $pin.querySelectorAll('[ref]');
Array.prototype.forEach.call($refList, ($ref) => {
const ref = $ref.getAttribute('ref');
if (ref) {
pinI.refs[ref] = $ref;
}
});
const pinData = pinDataList[index];
pinI.init(pinData, pin, blockName, index);
pinI.$root = $pin;
pinI.onInit();
pinI.onUpdate();
return $pin;
}
exports.generateInputPinHTML = generateInputPinHTML;
/**
* 生成 pin 的样式代码
* @param config
* @returns
*/
function generateStyle(blockDesc) {
return /*css*/ `
.pin {
--param-color: #fff;
--line—margin: 6px;
line-height: calc(var(--header-height) - 4px);
margin: var(--line—margin) 10px 0 10px;
position: relative;
}
.pin:last-child {
padding-bottom: var(--line—margin);
}
.pin.in {
}
.pin.out {
text-align: right;
}
.pin.in > .point[hidden], .pin.out > .point[hidden] {
display: none;
}
.pin.in > .point, .pin.out > .point {
display: block;
border: 1px solid var(--param-color);
transform: rotate(45deg);
width: 7px;
height: 7px;
position: absolute;
top: 6px;
transition: all 0.2s;
background: var(--background-color);
z-index: 1;
cursor: pointer;
}
.pin.in > .point {
left: -14px;
}
.pin.out > .point {
right: -14px;
}
.pin.in > .point:hover,
.pin.in > .point[active],
.pin.out > .point:hover,
.pin.out > .point[active]
{
background: var(--param-color);
}
.pin > .body {
display: flex;
}
.pin > .body > .name {
flex: 1;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.pin > .body > .name > .name {
padding: 0 6px;
}
.pin > .body > .slot-content {
flex: 1;
display: flex;
width: 120px;
}
.pin > .children, .pin > .children > div {
margin-top: calc(var(--line—margin) * 0.5);
}
.pin > .body > .slot-content[hidden], .pin > .children[hidden] {
display: none;
}
`;
}
exports.generateStyle = generateStyle;
function declarePin(define) {
const type = define.type;
TYPE[type] = define;
}
exports.declarePin = declarePin;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pin.js","sourceRoot":"","sources":["../../src/block-forge/pin.ts"],"names":[],"mappings":"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","sourcesContent":["'use strict';\n\n/**\n * Pin 引脚内置的类型\n */\n\nimport type { LineInfo } from '@itharbors/ui-graph';\nimport type { BaseElement } from '@itharbors/ui-core';\nimport type { IPinDescription, IBlockDescription, PinData } from './interface';\nimport type {\n    HTMLGraphForgeElement,\n} from './forge';\n\nimport {\n    Action,\n    ActionList,\n} from '@itharbors/structures';\n\nexport type DirtyDetail = {\n    action?: Action;\n};\n\nconst TYPE: {\n    [key: string]: new(...args: any[]) => Pin\n} = {};\n\ntype PinActionDetail = {\n    blockName: string;\n    index: number;\n};\n\nexport class PinAction<D extends {}> extends Action<D & PinActionDetail> {\n\n    pin: Pin;\n\n    // details: D & PinActionDetail;\n\n    constructor(pin: Pin, details: D) {\n        const cDetails = details as D & PinActionDetail;\n        cDetails.blockName = pin.pathData.blockName;\n        cDetails.index = pin.pathData.index;\n        super(cDetails);\n        // this.details = cDetails;\n        this.pin = pin;\n    }\n\n    exec(params: {\n        forge: HTMLGraphForgeElement\n    }) {\n\n    }\n\n    revertAction() {\n        return new PinAction(this.pin, {});\n    }\n}\n\nexport class Pin<D = { [key: string]: any }> {\n    static type = 'unknown';\n\n    color = 'white';\n    line = '';\n    style = '';\n    details?: D;\n\n    pathData = {\n        blockName: '',\n        index: 0,\n    };\n\n    desc!: IPinDescription;\n\n    contentSlot?: string;\n    childrenSlot?: string[];\n\n    refs: { [key: string]: HTMLElement } = {};\n    $root?: HTMLElement;\n\n    init(details: D, desc: IPinDescription, blockName: string, index: number) {\n        this.details = details;\n        this.pathData.blockName = blockName;\n        this.pathData.index = index;\n        this.desc = desc;\n    }\n\n    exec(action: Action) {\n        if (!this.$root) {\n            return;\n        }\n        const nodeRoot = this.$root.getRootNode() as ShadowRoot;\n        if (nodeRoot) {\n            (nodeRoot.host as BaseElement).dispatch('dirty', {\n                detail: {\n                    action,\n                },\n            });\n        }\n    }\n\n    onInit() {\n\n    }\n\n    onUpdate() {\n\n    }\n}\n\n// todo 考虑数据冲突\n\nfunction generateIcon(pin: IPinDescription) {\n    if (pin.icon) {\n        return /*html*/`<ui-icon value=\"${pin.icon}\"></ui-icon>`;\n    }\n    return '';\n}\n\nfunction generateTitle(pin: IPinDescription) {\n    if (pin.name) {\n        return /*html*/`<span class=\"name\" title=\"${pin.name}\">${pin.name}</span>`;\n    }\n    return '';\n}\n\n/**\n * 生成 output pin 的 HTML\n * @param pin\n * @param details\n * @returns\n */\nexport function generateOutputPinHTML(pin: IPinDescription, details: { value: any }) {\n    const type = pin.dataType as keyof typeof TYPE;\n    const define = TYPE[type] || TYPE['unknown'];\n    const pinI = new define();\n    const color = pinI.color ? `--param-color: ${pinI.color};` : '';\n\n    const $pin = document.createElement('div');\n    $pin.classList.add('pin');\n    $pin.classList.add('out');\n    $pin.classList.add(type + '');\n\n    // @ts-ignore\n    $pin.__pin = pinI;\n\n    $pin.innerHTML = /*html*/`${pinI.style ? `<style>${pinI.style}</style>` : ''}\n    <div class=\"body\">\n        <div class=\"name\">\n            ${generateTitle(pin)}\n            ${generateIcon(pin)}\n        </div>\n    </div>\n\n    <v-graph-node-param ${pin.hidePin ? 'hidden' : ''} style=\"${color}\" class=\"point\" direction=\"output\" name=\"${pin.tag}\" type=\"${type}\" role=\"right\"></v-graph-node-param>`;\n\n    const $refList = $pin.querySelectorAll('[ref]');\n    Array.prototype.forEach.call($refList, ($ref) => {\n        const ref = $ref.getAttribute('ref');\n        if (ref) {\n            pinI.refs[ref] = $ref;\n        }\n    });\n\n    pinI.details = details;\n    // pinI.onInit();\n    // pinI.onUpdate(details);\n    return $pin;\n}\n\n/**\n * 生成 input pin 的 HTML\n * @param pin\n * @param pinData\n * @param blockName\n * @param lineMap\n * @returns\n */\nexport function generateInputPinHTML(pin: IPinDescription, pinDataList: PinData[], index: number, blockName: string, lineMap: { [key: string]: LineInfo | undefined }) {\n    const type = pin.dataType as keyof typeof TYPE;\n    const define = TYPE[type] || TYPE['unknown'];\n    const pinI = new define();\n    const color = pinI.color ? `--param-color: ${pinI.color};` : '';\n\n    let connected = false;\n    for (const id in lineMap) {\n        const line = lineMap[id];\n        if (\n            line &&\n            line.output.node === blockName &&\n            line.output.param === pin.tag\n        ) {\n            connected = true;\n        }\n    }\n\n    const $pin = document.createElement('div');\n    $pin.classList.add('pin');\n    $pin.classList.add('in');\n    $pin.classList.add(type + '');\n\n    // @ts-ignore\n    $pin.__pin = pinI;\n\n    $pin.innerHTML = /*html*/`${pinI.style ? `<style>${pinI.style}</style>` : ''}\n    <div class=\"body\">\n        <div class=\"name\">\n            ${generateIcon(pin)}\n            ${generateTitle(pin)}\n        </div>\n        ${pinI.contentSlot ? `<div class=\"slot-content\" ${connected ? 'hidden' : ''}>${pinI.contentSlot}</div>` : ''}\n    </div>\n\n    ${pinI.childrenSlot ? `<div class=\"children\" ${connected ? 'hidden' : ''}>${pinI.childrenSlot.map(child => '<div class=\"slot-children\">' + child + '</div>').join('')}</div>` : ''}\n    <v-graph-node-param ${pin.hidePin ? 'hidden' : ''} style=\"${color}\" class=\"point\" direction=\"input\" name=\"${pin.tag}\" type=\"${type}\" role=\"left\"></v-graph-node-param>`;\n\n    const $refList = $pin.querySelectorAll('[ref]');\n    Array.prototype.forEach.call($refList, ($ref) => {\n        const ref = $ref.getAttribute('ref');\n        if (ref) {\n            pinI.refs[ref] = $ref;\n        }\n    });\n\n    const pinData = pinDataList[index];\n\n    pinI.init(pinData, pin, blockName, index);\n    pinI.$root = $pin;\n    pinI.onInit();\n    pinI.onUpdate();\n    return $pin;\n}\n\n/**\n * 生成 pin 的样式代码\n * @param config\n * @returns\n */\nexport function generateStyle(blockDesc: IBlockDescription) {\n    return /*css*/`\n.pin {\n    --param-color: #fff;\n    --line—margin: 6px;\n\n    line-height: calc(var(--header-height) - 4px);\n    margin: var(--line—margin) 10px 0 10px;\n    position: relative;\n}\n.pin:last-child {\n    padding-bottom: var(--line—margin);\n}\n.pin.in {\n\n}\n.pin.out {\n    text-align: right;\n}\n.pin.in > .point[hidden], .pin.out > .point[hidden] {\n    display: none;\n}\n\n.pin.in > .point, .pin.out > .point {\n    display: block;\n    border: 1px solid var(--param-color);\n    transform: rotate(45deg);\n    width: 7px;\n    height: 7px;\n    position: absolute;\n    top: 6px;\n    transition: all 0.2s;\n    background: var(--background-color);\n    z-index: 1;\n    cursor: pointer;\n}\n.pin.in > .point {\n    left: -14px;\n}\n.pin.out > .point {\n    right: -14px;\n}\n.pin.in > .point:hover,\n.pin.in > .point[active],\n.pin.out > .point:hover,\n.pin.out > .point[active]\n{\n    background: var(--param-color);\n}\n\n.pin > .body {\n    display: flex;\n}\n.pin > .body > .name {\n    flex: 1;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n}\n\n.pin > .body > .name > .name {\n    padding: 0 6px;\n}\n\n.pin > .body > .slot-content {\n    flex: 1;\n    display: flex;\n    width: 120px;\n}\n\n.pin > .children, .pin > .children > div {\n    margin-top: calc(var(--line—margin) * 0.5);\n}\n\n.pin > .body > .slot-content[hidden], .pin > .children[hidden] {\n    display: none;\n}\n    `;\n}\n\nexport function declarePin(define: new(...args: any[]) => Pin) {\n    const type = (define as unknown as typeof Pin).type;\n    TYPE[type] = define;\n}\n"]}