'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*/ ``; } return ''; } function generateTitle(pin) { if (pin.name) { return /*html*/ `${pin.name}`; } 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 ? `` : ''}
${generateTitle(pin)} ${generateIcon(pin)}
`; 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 ? `` : ''}
${generateIcon(pin)} ${generateTitle(pin)}
${pinI.contentSlot ? `
${pinI.contentSlot}
` : ''}
${pinI.childrenSlot ? `
${pinI.childrenSlot.map(child => '
' + child + '
').join('')}
` : ''} `; 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"]}