UNPKG

primevue

Version:

PrimeVue is an open source UI library for Vue featuring a rich set of 80+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with PrimeBloc

116 lines (110 loc) 4.04 kB
import TerminalService from 'primevue/terminalservice'; import BaseComponent from '@primevue/core/basecomponent'; import TerminalStyle from 'primevue/terminal/style'; import { createElementBlock, openBlock, mergeProps, createCommentVNode, createElementVNode, toDisplayString, Fragment, renderList, withDirectives, vModelText } from 'vue'; var script$1 = { name: 'BaseTerminal', "extends": BaseComponent, props: { welcomeMessage: { type: String, "default": null }, prompt: { type: String, "default": null } }, style: TerminalStyle, provide: function provide() { return { $pcTerminal: this, $parentInstance: this }; } }; var script = { name: 'Terminal', "extends": script$1, inheritAttrs: false, data: function data() { return { commandText: null, commands: [] }; }, mounted: function mounted() { TerminalService.on('response', this.responseListener); this.$refs.input.focus(); }, updated: function updated() { this.$el.scrollTop = this.$el.scrollHeight; }, beforeUnmount: function beforeUnmount() { TerminalService.off('response', this.responseListener); }, methods: { onClick: function onClick() { this.$refs.input.focus(); }, onKeydown: function onKeydown(event) { if (event.key === 'Enter' && this.commandText) { this.commands.push({ text: this.commandText }); TerminalService.emit('command', this.commandText); this.commandText = ''; } }, responseListener: function responseListener(response) { this.commands[this.commands.length - 1].response = response; } } }; function render(_ctx, _cache, $props, $setup, $data, $options) { return openBlock(), createElementBlock("div", mergeProps({ "class": _ctx.cx('root'), onClick: _cache[2] || (_cache[2] = function () { return $options.onClick && $options.onClick.apply($options, arguments); }) }, _ctx.ptmi('root')), [_ctx.welcomeMessage ? (openBlock(), createElementBlock("div", mergeProps({ key: 0, "class": _ctx.cx('welcomeMessage') }, _ctx.ptm('welcomeMessage')), toDisplayString(_ctx.welcomeMessage), 17)) : createCommentVNode("", true), createElementVNode("div", mergeProps({ "class": _ctx.cx('commandList') }, _ctx.ptm('content')), [(openBlock(true), createElementBlock(Fragment, null, renderList($data.commands, function (command, i) { return openBlock(), createElementBlock("div", mergeProps({ key: command.text + i.toString(), "class": _ctx.cx('command'), ref_for: true }, _ctx.ptm('commands')), [createElementVNode("span", mergeProps({ "class": _ctx.cx('promptLabel'), ref_for: true }, _ctx.ptm('prompt')), toDisplayString(_ctx.prompt), 17), createElementVNode("span", mergeProps({ "class": _ctx.cx('commandValue'), ref_for: true }, _ctx.ptm('command')), toDisplayString(command.text), 17), createElementVNode("div", mergeProps({ "class": _ctx.cx('commandResponse'), "aria-live": "polite", ref_for: true }, _ctx.ptm('response')), toDisplayString(command.response), 17)], 16); }), 128))], 16), createElementVNode("div", mergeProps({ "class": _ctx.cx('prompt') }, _ctx.ptm('container')), [createElementVNode("span", mergeProps({ "class": _ctx.cx('promptLabel') }, _ctx.ptm('prompt')), toDisplayString(_ctx.prompt), 17), withDirectives(createElementVNode("input", mergeProps({ ref: "input", "onUpdate:modelValue": _cache[0] || (_cache[0] = function ($event) { return $data.commandText = $event; }), "class": _ctx.cx('promptValue'), type: "text", autocomplete: "off", onKeydown: _cache[1] || (_cache[1] = function () { return $options.onKeydown && $options.onKeydown.apply($options, arguments); }) }, _ctx.ptm('commandText')), null, 16), [[vModelText, $data.commandText]])], 16)], 16); } script.render = render; export { script as default }; //# sourceMappingURL=index.mjs.map