dcl-npc-toolkit-ai-version
Version:
A collection of tools for creating Non-Player-Characters (NPCs). These are capable of having conversations with the player, and play different animations. AI usage is added atop of it
201 lines • 30.1 kB
JavaScript
import ReactEcs, { Input, Label, UiEntity } from '@dcl/sdk/react-ecs';
import { realHeight, realWidth } from "./dialog";
import { Color4 } from '@dcl/sdk/math';
import { modalScale, modelFontSizeScale } from './ui';
let isVisible = false;
let input_title = "";
let input_description = "";
let current_input = "";
let input_callback = () => {
};
function getScaledSize(size) {
return size * modalScale;
}
export const NpcUtilsInputUi = () => {
const width = getScaledSize(realWidth(700));
const height = getScaledSize(realHeight(284));
return (ReactEcs.createElement(UiEntity, { uiTransform: {
positionType: 'absolute',
width: getScaledSize(width),
height: getScaledSize(height),
position: { bottom: "30%", left: '50%' },
margin: { top: -height / 2, left: -width / 2 },
display: isVisible ? 'flex' : 'none'
} },
ReactEcs.createElement(UiEntity, { uiTransform: {
width: '100%',
height: '100%',
justifyContent: 'space-around',
alignItems: 'stretch',
display: 'flex',
flexWrap: 'wrap',
flexDirection: 'row'
}, uiBackground: {
texture: { src: "https://i.ibb.co/8mcxBVm/notification.png" },
textureMode: 'stretch'
} },
ReactEcs.createElement(UiEntity, { uiTransform: {
width: '100%',
height: '10%',
margin: { top: '2%' },
justifyContent: 'center'
} },
ReactEcs.createElement(UiEntity, { uiTransform: {
height: '100%',
width: '100%',
justifyContent: 'center'
} },
ReactEcs.createElement(Label, { value: `<b>${input_title}</b>`, fontSize: getScaledFontSize(28) })),
ReactEcs.createElement(UiEntity, { uiTransform: {
positionType: 'absolute',
position: { top: '6.5%', right: '3%' },
width: getScaledSize(17.5),
height: getScaledSize(17.5),
}, onMouseDown: () => {
closeInput(true);
}, uiBackground: {
texture: { src: "https://i.ibb.co/zfDpTtW/close-Button.png" },
textureMode: 'stretch',
color: Color4.White()
} })),
ReactEcs.createElement(UiEntity, { uiTransform: {
width: '95%',
height: '20%',
flexDirection: 'column',
} },
ReactEcs.createElement(Label, { value: `<b>${input_description}</b>`, fontSize: getScaledFontSize(28) })),
ReactEcs.createElement(UiEntity, { uiTransform: {
height: '15%',
width: '85%'
}, uiBackground: {
texture: { src: "https://i.ibb.co/5WkcjKT/inputUi.png" },
textureMode: 'stretch'
} }, editInputUI()),
ReactEcs.createElement(UiEntity, { uiTransform: {
width: '100%',
height: '12%',
flexDirection: 'row'
} },
ReactEcs.createElement(UiEntity, { uiTransform: {
positionType: 'absolute',
position: { right: "20%" },
width: getScaledSize(140),
height: getScaledSize(48),
}, onMouseDown: () => {
input_callback(current_input);
closeInput(true);
}, uiBackground: {
texture: { src: "https://i.ibb.co/RB5PNYj/yes-Button.png" },
textureMode: 'stretch',
color: Color4.White()
} }),
ReactEcs.createElement(UiEntity, { uiTransform: {
positionType: 'absolute',
position: { left: "20%" },
width: getScaledSize(140),
height: getScaledSize(48),
}, onMouseDown: () => {
closeInput(true);
}, uiBackground: {
texture: { src: "https://i.ibb.co/fxmsqjv/noButton.png" },
textureMode: 'stretch',
color: Color4.White()
} })))));
};
const editInputUI = () => {
if (isVisible) {
return (ReactEcs.createElement(UiEntity, { uiTransform: {
width: "95%",
height: '80%',
margin: { left: "2.5%", top: '1%' }
} },
ReactEcs.createElement(Input, { uiTransform: {
width: "100%",
height: '100%'
}, fontSize: getScaledFontSize(20), placeholder: isVisible ? "Input here" : "Error", color: Color4.White(), placeholderColor: Color4.White(), onSubmit: () => {
input_callback(current_input);
closeInput(true);
}, onChange: (x) => {
onEdit(x);
} })));
}
else {
return (ReactEcs.createElement(UiEntity, null));
}
};
function getScaledFontSize(size) {
return size * modelFontSizeScale;
}
function setVisibility(status) {
isVisible = status;
}
export function isInputVisible() {
return isVisible;
}
export function closeInput(triggerWalkAway = true) {
if (isVisible == false)
return;
setVisibility(false);
if (!triggerWalkAway)
return;
}
export function invokeInput(title, text, callback, initial_value = "") {
input_title = title;
input_description = text;
input_callback = callback;
setVisibility(true);
}
function onEdit(param) {
current_input = param;
}
export const NpcUtilsLoadingUi = () => {
const width = getScaledSize(realWidth(700));
const height = getScaledSize(realHeight(200));
return (ReactEcs.createElement(UiEntity, { uiTransform: {
positionType: 'absolute',
width: getScaledSize(width),
height: getScaledSize(height),
position: { bottom: "30%", left: '50%' },
margin: { top: -height / 2, left: -width / 2 },
display: isLoadingVisible ? 'flex' : 'none'
} },
ReactEcs.createElement(UiEntity, { uiTransform: {
width: '100%',
height: '100%',
justifyContent: 'space-around',
alignItems: 'stretch',
display: 'flex',
flexWrap: 'wrap',
flexDirection: 'row'
}, uiBackground: {
texture: { src: "https://i.ibb.co/8mcxBVm/notification.png" },
textureMode: 'stretch'
} },
ReactEcs.createElement(UiEntity, { uiTransform: {
width: '100%',
height: '96%',
margin: { top: '2%' },
justifyContent: 'center'
} },
ReactEcs.createElement(UiEntity, { uiTransform: {
height: '100%',
width: '100%',
justifyContent: 'center'
} },
ReactEcs.createElement(Label, { value: `<b>LOADING RESPONSE...</b>`, fontSize: getScaledFontSize(36) }))))));
};
let isLoadingVisible = false;
function setLoadingVisibility(status) {
isLoadingVisible = status;
}
export function closeLoading(triggerWalkAway = true) {
if (isLoadingVisible == false)
return;
setLoadingVisibility(false);
if (!triggerWalkAway)
return;
}
export function invokeLoading() {
setLoadingVisibility(true);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uiInput.js","sourceRoot":"","sources":["../src/uiInput.tsx"],"names":[],"mappings":"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","sourcesContent":["import ReactEcs, { Input, Label, UiEntity } from '@dcl/sdk/react-ecs'\nimport { realHeight, realWidth } from \"./dialog\"\nimport { Color4 } from '@dcl/sdk/math'\nimport { modalScale, modelFontSizeScale } from './ui'\n\nlet isVisible: boolean = false\nlet input_title: string = \"\"\nlet input_description: string = \"\"\nlet current_input: string = \"\"\nlet input_callback: any = () => {\n}\n\nfunction getScaledSize(size: number): number {\n    return size * modalScale\n}\n\n// This is UI element for inputing string prompts\nexport const NpcUtilsInputUi = () => {\n    const width = getScaledSize(realWidth(700))\n    const height = getScaledSize(realHeight(284))\n    return (\n        <UiEntity //Invisible Parent\n            uiTransform={{\n                positionType: 'absolute',\n                width: getScaledSize(width),\n                height: getScaledSize(height),\n                position: {bottom: \"30%\", left: '50%'},\n                margin: { top: -height / 2, left: -width / 2 },\n                display: isVisible ? 'flex' : 'none'\n            }}\n        >\n\n            <UiEntity //Dialog Holder\n                uiTransform={{\n                    width: '100%',\n                    height: '100%',\n                    justifyContent: 'space-around',\n                    alignItems: 'stretch',\n                    display: 'flex',\n                    flexWrap: 'wrap',\n                    flexDirection: 'row'\n                }}\n                uiBackground={{\n                    texture: {src: \"https://i.ibb.co/8mcxBVm/notification.png\"},\n                    textureMode: 'stretch'\n                }}\n            >\n\n                <UiEntity //TOP\n                    uiTransform={{\n                        width: '100%',\n                        height: '10%',\n                        margin: {top: '2%'},\n                        justifyContent: 'center'\n                    }}\n                >\n\n                    <UiEntity\n                        uiTransform={{\n                            height: '100%',\n                            width: '100%',\n                            justifyContent: 'center'\n                        }}\n                    >\n                        <Label\n                            value={`<b>${input_title}</b>`}\n                            fontSize={getScaledFontSize(28)}\n                        ></Label>\n\n                    </UiEntity>\n\n                    <UiEntity //Close icon\n                        uiTransform={{\n                            positionType: 'absolute',\n                            position: {top: '6.5%', right: '3%'},\n                            width: getScaledSize(17.5),\n                            height: getScaledSize(17.5),\n                        }}\n                        onMouseDown={() => {\n                            closeInput(true)\n                        }}\n                        uiBackground={{\n                            texture: {src: \"https://i.ibb.co/zfDpTtW/close-Button.png\"},\n                            textureMode: 'stretch',\n                            color: Color4.White()\n                        }}\n                    ></UiEntity>\n\n                </UiEntity>\n\n                <UiEntity // description\n                    uiTransform={{\n                        width: '95%',\n                        height: '20%',\n                        flexDirection: 'column',\n                    }}\n                >\n                    <Label\n                        value={`<b>${input_description}</b>`}\n                        fontSize={getScaledFontSize(28)}\n                    ></Label>\n                </UiEntity>\n\n                <UiEntity //Input\n                    uiTransform={{\n                        height: '15%',\n                        width: '85%'\n                    }}\n                    uiBackground={{\n                        texture: {src: \"https://i.ibb.co/5WkcjKT/inputUi.png\"},\n                        textureMode: 'stretch'\n                    }}\n\n                >\n\n                    {editInputUI()}\n\n                </UiEntity>\n\n                <UiEntity //Footer\n                    uiTransform={{\n                        width: '100%',\n                        height: '12%',\n                        flexDirection: 'row'\n                    }}\n                    //uiBackground={{textureMode:'stretch', color: Color4.Green()}}\n                >\n\n                    <UiEntity //Yes\n                        uiTransform={{\n                            positionType: 'absolute',\n                            position: {right: \"20%\"},\n                            width: getScaledSize(140),\n                            height: getScaledSize(48),\n                        }}\n                        onMouseDown={() => {\n                            input_callback(current_input);\n                            closeInput(true);\n                        }}\n                        uiBackground={{\n                            texture: {src: \"https://i.ibb.co/RB5PNYj/yes-Button.png\"},\n                            textureMode: 'stretch',\n                            color: Color4.White()\n                        }}\n                    ></UiEntity>\n\n                    <UiEntity //No\n                        uiTransform={{\n                            positionType: 'absolute',\n                            position: {left: \"20%\"},\n                            width: getScaledSize(140),\n                            height: getScaledSize(48),\n                        }}\n                        onMouseDown={() => {\n                            closeInput(true)\n                        }}\n\n                        uiBackground={{\n                            texture: {src: \"https://i.ibb.co/fxmsqjv/noButton.png\"},\n                            textureMode: 'stretch',\n                            color: Color4.White()\n                        }}\n                    ></UiEntity>\n\n                </UiEntity>\n            </UiEntity>\n        </UiEntity>\n    )\n}\n\nconst editInputUI = () => {\n    if (isVisible) {\n        return (\n            <UiEntity\n                uiTransform={{\n                    width: \"95%\",\n                    height: '80%',\n                    margin: {left: \"2.5%\", top: '1%'}\n                }}\n            >\n                <Input\n                    uiTransform={{\n                        width: \"100%\",\n                        height: '100%'\n                    }}\n                    fontSize={getScaledFontSize(20)}\n                    placeholder={isVisible ? \"Input here\" : \"Error\"}\n                    color={Color4.White()}\n                    placeholderColor={Color4.White()}\n                    onSubmit={() => {\n                        input_callback(current_input);\n                        closeInput(true);\n                    }}\n                    onChange={(x) => {\n                        onEdit(x)\n                    }}\n                />\n            </UiEntity>)\n    } else {\n        return (<UiEntity></UiEntity>)\n    }\n}\n\nfunction getScaledFontSize(size: number): number {\n    return size * modelFontSizeScale\n}\n\nfunction setVisibility(status: boolean): void {\n    isVisible = status\n}\n\nexport function isInputVisible() {\n    return isVisible;\n}\n\nexport function closeInput(triggerWalkAway: boolean = true) {\n    if (isVisible == false) return\n    setVisibility(false)\n    if (!triggerWalkAway) return\n}\n\nexport function invokeInput(title: string, text: string, callback: any, initial_value: string = \"\") {\n    input_title = title;\n    input_description = text;\n    input_callback = callback;\n    setVisibility(true)\n}\n\nfunction onEdit(param: string) {\n    current_input = param;\n}\n\n\nexport const NpcUtilsLoadingUi = () => {\n    const width = getScaledSize(realWidth(700))\n    const height = getScaledSize(realHeight(200))\n    return (\n        <UiEntity //Invisible Parent\n            uiTransform={{\n                positionType: 'absolute',\n                width: getScaledSize(width),\n                height: getScaledSize(height),\n                position: {bottom: \"30%\", left: '50%'},\n                margin: { top: -height / 2, left: -width / 2 },\n                display: isLoadingVisible ? 'flex' : 'none'\n            }}\n        >\n\n            <UiEntity //Dialog Holder\n                uiTransform={{\n                    width: '100%',\n                    height: '100%',\n                    justifyContent: 'space-around',\n                    alignItems: 'stretch',\n                    display: 'flex',\n                    flexWrap: 'wrap',\n                    flexDirection: 'row'\n                }}\n                uiBackground={{\n                    texture: {src: \"https://i.ibb.co/8mcxBVm/notification.png\"},\n                    textureMode: 'stretch'\n                }}\n            >\n\n                <UiEntity //TOP\n                    uiTransform={{\n                        width: '100%',\n                        height: '96%',\n                        margin: {top: '2%'},\n                        justifyContent: 'center'\n                    }}\n                >\n\n                    <UiEntity\n                        uiTransform={{\n                            height: '100%',\n                            width: '100%',\n                            justifyContent: 'center'\n                        }}\n                    >\n                        <Label\n                            value={`<b>LOADING RESPONSE...</b>`}\n                            fontSize={getScaledFontSize(36)}\n                        ></Label>\n\n                    </UiEntity>\n\n                </UiEntity>\n            </UiEntity>\n        </UiEntity>\n    )\n}\n\nlet isLoadingVisible = false;\n\nfunction setLoadingVisibility(status: boolean): void {\n    isLoadingVisible = status\n}\n\nexport function closeLoading(triggerWalkAway: boolean = true) {\n    if (isLoadingVisible == false) return\n    setLoadingVisibility(false)\n    if (!triggerWalkAway) return\n}\n\nexport function invokeLoading() {\n    setLoadingVisibility(true)\n}"]}