Skip to content

Commit

Permalink
Merge pull request #3289 from processing/fix-errors
Browse files Browse the repository at this point in the history
Fix Console Errors and Update Hooks in FileNode
  • Loading branch information
raclim authored Dec 2, 2024
2 parents 5ab73a7 + 12c4d3f commit 2c92035
Show file tree
Hide file tree
Showing 5 changed files with 132 additions and 147 deletions.
4 changes: 3 additions & 1 deletion client/modules/IDE/components/ConsoleInput.jsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import PropTypes from 'prop-types';
import React, { useRef, useEffect, useState } from 'react';
import { useDispatch } from 'react-redux';
import CodeMirror from 'codemirror';
import { Encode } from 'console-feed';

Expand All @@ -15,6 +16,7 @@ function ConsoleInput({ theme, fontSize }) {
const [commandCursor, setCommandCursor] = useState(-1);
const codemirrorContainer = useRef(null);
const cmInstance = useRef(null);
const dispatch = useDispatch();

useEffect(() => {
cmInstance.current = CodeMirror(codemirrorContainer.current, {
Expand Down Expand Up @@ -45,7 +47,7 @@ function ConsoleInput({ theme, fontSize }) {
payload: { source: 'console', messages }
});

dispatchConsoleEvent(consoleEvent);
dispatch(dispatchConsoleEvent(consoleEvent));
cm.setValue('');
setCommandHistory([value, ...commandHistory]);
setCommandCursor(-1);
Expand Down
131 changes: 31 additions & 100 deletions client/modules/IDE/components/FileNode.jsx
Original file line number Diff line number Diff line change
@@ -1,43 +1,17 @@
import PropTypes from 'prop-types';
import classNames from 'classnames';
import React, { useState, useRef } from 'react';
import { connect } from 'react-redux';
import { useDispatch, useSelector } from 'react-redux';
import { useTranslation } from 'react-i18next';

import * as IDEActions from '../actions/ide';
import * as FileActions from '../actions/files';
import parseFileName from '../utils/parseFileName';
import DownArrowIcon from '../../../images/down-filled-triangle.svg';
import FolderRightIcon from '../../../images/triangle-arrow-right.svg';
import FolderDownIcon from '../../../images/triangle-arrow-down.svg';
import FileTypeIcon from './FileTypeIcon';

function parseFileName(name) {
const nameArray = name.split('.');
if (nameArray.length > 1) {
const extension = `.${nameArray[nameArray.length - 1]}`;
const baseName = nameArray.slice(0, -1).join('.');
const firstLetter = baseName[0];
const lastLetter = baseName[baseName.length - 1];
const middleText = baseName.slice(1, -1);
return {
baseName,
firstLetter,
lastLetter,
middleText,
extension
};
}
const firstLetter = name[0];
const lastLetter = name[name.length - 1];
const middleText = name.slice(1, -1);
return {
baseName: name,
firstLetter,
lastLetter,
middleText
};
}

function FileName({ name }) {
const {
baseName,
Expand All @@ -62,40 +36,35 @@ FileName.propTypes = {
name: PropTypes.string.isRequired
};

const FileNode = ({
id,
parentId,
children,
name,
fileType,
isSelectedFile,
isFolderClosed,
setSelectedFile,
deleteFile,
updateFileName,
resetSelectedFile,
newFile,
newFolder,
showFolderChildren,
hideFolderChildren,
canEdit,
openUploadFileModal,
authenticated,
onClickFile
}) => {
const FileNode = ({ id, canEdit, onClickFile }) => {
const dispatch = useDispatch();
const { t } = useTranslation();

const fileNode =
useSelector((state) => state.files.find((file) => file.id === id)) || {};
const authenticated = useSelector((state) => state.user.authenticated);

const {
name = '',
parentId = null,
children = [],
fileType = 'file',
isSelectedFile = false,
isFolderClosed = false
} = fileNode;

const [isOptionsOpen, setIsOptionsOpen] = useState(false);
const [isEditingName, setIsEditingName] = useState(false);
const [isDeleting, setIsDeleting] = useState(false);
const [updatedName, setUpdatedName] = useState(name);

const { t } = useTranslation();
const fileNameInput = useRef(null);
const fileOptionsRef = useRef(null);

const handleFileClick = (event) => {
event.stopPropagation();
if (name !== 'root' && !isDeleting) {
setSelectedFile(id);
dispatch(IDEActions.setSelectedFile(id));
}
if (onClickFile) {
onClickFile();
Expand All @@ -122,17 +91,17 @@ const FileNode = ({
};

const handleClickAddFile = () => {
newFile(id);
dispatch(IDEActions.newFile(id));
setTimeout(() => hideFileOptions(), 0);
};

const handleClickAddFolder = () => {
newFolder(id);
dispatch(IDEActions.newFolder(id));
setTimeout(() => hideFileOptions(), 0);
};

const handleClickUploadFile = () => {
openUploadFileModal(id);
dispatch(IDEActions.openUploadFileModal(id));
setTimeout(hideFileOptions, 0);
};

Expand All @@ -141,8 +110,8 @@ const FileNode = ({

if (window.confirm(prompt)) {
setIsDeleting(true);
resetSelectedFile(id);
setTimeout(() => deleteFile(id, parentId), 100);
dispatch(IDEActions.resetSelectedFile(id));
setTimeout(() => dispatch(FileActions.deleteFile(id, parentId), 100));
}
};

Expand All @@ -158,7 +127,7 @@ const FileNode = ({

const saveUpdatedFileName = () => {
if (updatedName !== name) {
updateFileName(id, updatedName);
dispatch(FileActions.updateFileName(id, updatedName));
}
};

Expand Down Expand Up @@ -243,7 +212,7 @@ const FileNode = ({
<div className="sidebar__file-item--folder">
<button
className="sidebar__file-item-closed"
onClick={() => showFolderChildren(id)}
onClick={() => dispatch(FileActions.showFolderChildren(id))}
aria-label={t('FileNode.OpenFolderARIA')}
title={t('FileNode.OpenFolderARIA')}
>
Expand All @@ -255,7 +224,7 @@ const FileNode = ({
</button>
<button
className="sidebar__file-item-open"
onClick={() => hideFolderChildren(id)}
onClick={() => dispatch(FileActions.hideFolderChildren(id))}
aria-label={t('FileNode.CloseFolderARIA')}
title={t('FileNode.CloseFolderARIA')}
>
Expand Down Expand Up @@ -353,7 +322,7 @@ const FileNode = ({
<ul className="file-item__children">
{children.map((childId) => (
<li key={childId}>
<ConnectedFileNode
<FileNode
id={childId}
parentId={id}
canEdit={canEdit}
Expand All @@ -369,50 +338,12 @@ const FileNode = ({

FileNode.propTypes = {
id: PropTypes.string.isRequired,
parentId: PropTypes.string,
children: PropTypes.arrayOf(PropTypes.string.isRequired).isRequired,
name: PropTypes.string.isRequired,
fileType: PropTypes.string.isRequired,
isSelectedFile: PropTypes.bool,
isFolderClosed: PropTypes.bool,
setSelectedFile: PropTypes.func.isRequired,
deleteFile: PropTypes.func.isRequired,
updateFileName: PropTypes.func.isRequired,
resetSelectedFile: PropTypes.func.isRequired,
newFile: PropTypes.func.isRequired,
newFolder: PropTypes.func.isRequired,
showFolderChildren: PropTypes.func.isRequired,
hideFolderChildren: PropTypes.func.isRequired,
canEdit: PropTypes.bool.isRequired,
openUploadFileModal: PropTypes.func.isRequired,
authenticated: PropTypes.bool.isRequired,
onClickFile: PropTypes.func
};

FileNode.defaultProps = {
onClickFile: null,
parentId: '0',
isSelectedFile: false,
isFolderClosed: false
onClickFile: null
};

function mapStateToProps(state, ownProps) {
// this is a hack, state is updated before ownProps
const fileNode = state.files.find((file) => file.id === ownProps.id) || {
name: 'test',
fileType: 'file'
};
return Object.assign({}, fileNode, {
authenticated: state.user.authenticated
});
}

const mapDispatchToProps = { ...FileActions, ...IDEActions };

const ConnectedFileNode = connect(
mapStateToProps,
mapDispatchToProps
)(FileNode);

export { FileNode };
export default ConnectedFileNode;
export default FileNode;
Loading

0 comments on commit 2c92035

Please sign in to comment.