@kui-shell/plugin-client-common
Version:
Kui plugin that offers stylesheets
49 lines • 2.08 kB
JavaScript
/*
* Copyright 2020 The Kubernetes Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import React from 'react';
import { eventBus } from '@kui-shell/core/mdist/api/Events';
import KuiContext from './context';
import Block from '../Views/Terminal/Block';
import { Active } from '../Views/Terminal/Block/BlockModel';
import '../../../web/css/static/InputStripe.scss';
export default class InputStripe extends React.PureComponent {
constructor(props) {
super(props);
this._blockRef = React.createRef();
this.state = {
idx: 0,
model: Active()
};
}
componentDidMount() {
eventBus.onCommandComplete(this.props.uuid, this.onOutputRender.bind(this));
}
/** Command has completed in our tab */
onOutputRender() {
this.setState(curState => ({ idx: curState.idx + 1, model: Active() }));
}
doFocus() {
if (this._blockRef.current) {
this._blockRef.current.doFocus();
}
}
render() {
return (React.createElement(KuiContext.Provider, { value: { prompt: this.props.prompt || '\u276f' } },
React.createElement("div", { className: "kui--input-stripe repl" },
React.createElement(Block, { ref: this._blockRef, idx: this.state.idx, uuid: `${this.props.uuid}-${this.state.idx}`, tab: this.props.tab, model: this.state.model, noOutput: true, noPromptContext: true, isFocused: true, promptPlaceholder: this.props.promptPlaceholder }, this.props.children))));
}
}
//# sourceMappingURL=InputStripe.js.map