import React, { Component } from 'react'; import axios from 'axios' import { Spin } from 'antd' import ClipboardJS from 'clipboard' import VNCDisplay from './VNCDisplay' import FloatButton from './component/FloatButton' import SecondDrawer from './component/SecondDrawer' import RepoTree from './component/repo/RepoTree' import TPIMonaco from './component/monaco/TPIMonaco' import notEditablePathImg from '../../images/tpi/notEditablePath.png' import './VNC.css' const $ = window.$; const firstDrawerWidth = 260; class VNCContainer extends Component { constructor(props) { super(props) this.state = { fileTreeSelectedKeys: [], repositoryCode: '' } } componentDidMount() { if (!this.clipboard) { const clipboard = new ClipboardJS('.copybtn'); clipboard.on('success', (e) => { this.props.showSnackbar('复制成功') }); this.clipboard = clipboard } } getSecondDrawerWidth = () => { return $('#game_right_contents').width() - firstDrawerWidth } renderSecondDrawerChildren = () => { const { readingCodeLoading, repositoryCode } = this.state; const height = $(window).height() - 130 const isEditablePath = false; return (
); } fetchReadRepositoryCode = (path) => { const status = 1 const fetchRepoCodeUrl = `/tasks/${this.props.game.identifier}/rep_content.json?path=${path}&status=${status}` this.setState({ readingCodeLoading: true }); axios.get(fetchRepoCodeUrl, { }).then((fetchReadRepositoryCodeResponse) => { if (fetchReadRepositoryCodeResponse.data.content || fetchReadRepositoryCodeResponse.data.content == "") { this.setState({ repositoryCode: fetchReadRepositoryCodeResponse.data.content, readingCodeLoading: false }) } else { this.setState({ readingCodeLoading: false }); } // this.setState({ isEditablePath, currentPath: path }); }).catch(error =>{ console.log(error) this.setState({ readingCodeLoading: false }); this.props.showSnackbar(`服务端异常,请联系管理员!`); }) } onTreeSelect = (selectedKeys, info) => { const isLeaf = info.node.props.isLeaf; if (isLeaf) { // 叶子节点 selectedKeys.length && this.setState({ fileTreeSelectedKeys: selectedKeys }) this.refs["secondDrawer"].showSecondDrawer() console.log('leaf clicked') const nodePath = info.node.props.eventKey; if (nodePath) { const filetype = nodePath.split('.').pop().toLowerCase(); if (filetype == 'jpg' || filetype == 'png' || filetype == 'gif' || filetype == 'jpeg' || filetype == 'jar' || filetype == 'exe' || filetype == 'doc' || filetype == 'pdf' || filetype == 'xsl' || filetype == 'ppt') { this.props.showSnackbar(`不支持加载${filetype}类型的文件。`) return; } this.fetchReadRepositoryCode(nodePath); } else { console.error('no eventKey:', info.node) } } } /* selectedKeys={fileTreeSelectedKeys} onSelect={onTreeSelect} */ render() { const { challenge, vnc_url, git_url } = this.props const secondDrawerChildren = this.renderSecondDrawerChildren(); return (
网址克隆
); } } export default VNCContainer;