Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

story/VSPC-242 #345

Open
wants to merge 74 commits into
base: develop
Choose a base branch
from
Open

story/VSPC-242 #345

wants to merge 74 commits into from

Conversation

jophals
Copy link

@jophals jophals commented Jun 7, 2024

Guidelines for Pull Requests

If you haven't yet read our code review guidelines, please do so, You can find them here.

Please confirm the following by adding an x for each item (turn [ ] into [x]).

  • I have removed all code style changes that are not necessary (e.g. changing blanks across the whole file that don’t need to be changed, adding empty lines in parts other than your own code)
  • I am not making any changes to files that don’t have any effect (e.g. imports added that don’t need to be added)
  • I do not have any sysout statements in my code or commented out code that isn’t needed anymore
  • I am not reformatting any files in the wrong format or without cause.
  • I am not changing file encoding or line endings to something else than UTF-8, LF
  • My pull request does not show an insane amount of files being changed although my ticket only requires a few files being changed
  • I have added Javadoc/documentation where appropriate
  • I have added test cases where appropriate
  • I have explained any part of my code/implementation decisions that is not be self-explanatory

Please provide a brief description of your ticket

(you can copy the ticket if it hasn't changed)

Users should be able to include external links on their slides, which will be visible on the public page.

Anything else the reviewer needs to know?

This is my first Java PR!

@jophals jophals reopened this Jun 14, 2024

@OneToOne(targetEntity = VSImage.class)
@NotFound(action = NotFoundAction.IGNORE)
private IVSImage image;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should not be needed. slides don't have images

@@ -2,6 +2,7 @@

import edu.asu.diging.vspace.core.exception.ImageCouldNotBeStoredException;
import edu.asu.diging.vspace.core.exception.LinkDoesNotExistsException;
import edu.asu.diging.vspace.core.exception.SlideDoesNotExistException;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is this needed in this class?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

@@ -33,4 +33,7 @@ public interface ISlideManager {
List<Sequence> getSlideSequences(String slideId, String moduleId);

Page<ISlide> findByNameOrDescription(Pageable requestedPage,String searchText);

void storeSlideDisplay(ISlide slide, IVSImage image);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what is this for? should not be needed for this ticket.

@Override
protected IExternalLinkDisplay createDisplayLink(IExternalLink link) {
return null;
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what is this all about? this file should not need to be changed.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

$('#addChoice').show();
$('#choiceSpace').show();
[/]

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what is all this added for?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please fix this file so it's clear what has been changed. Right now i can't tell.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this still

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why is this file being changed?

import edu.asu.diging.vspace.core.model.display.ISlideExternalLinkDisplay;

@RunWith(MockitoJUnitRunner.class)
public class SlideExternalLinkDisplayFactoryTest {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There shouldn't be a ExternalLinkDisplayFactory anymore

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

slideImage.setWidth(1300);
slide.setImage(slideImage);

ISlideDisplay displayAttributes = new SlideDisplay();
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

there should be no such class

@jdamerow jdamerow closed this Jun 20, 2024
@jophals jophals reopened this Jul 18, 2024
@jophals jophals requested a review from jdamerow July 18, 2024 21:13

public List<IExternalLinkSlide> findBySlide_Id(String slideId);

public void deleteByExternalLink(IExternalLinkSlide link);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just deleteByExternalLink. I don't think we need this method.

@@ -2,6 +2,7 @@

import edu.asu.diging.vspace.core.exception.ImageCouldNotBeStoredException;
import edu.asu.diging.vspace.core.exception.LinkDoesNotExistsException;
import edu.asu.diging.vspace.core.exception.SlideDoesNotExistException;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

@Override
protected IExternalLinkDisplay createDisplayLink(IExternalLink link) {
return null;
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

}

@Override
public void removeFromLinkList(ISlide slide, IExternalLinkSlide link) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

does this really need a method? when you want to remove a link, you can just do it directly without calling this extra method.

}

@Override
public void addToLinkList(ISlide slide, IExternalLinkSlide link) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

does this really need a method? when you want to add a link, you can just do it directly without calling this extra method.

@@ -135,6 +136,7 @@ public String slide(Model model, @PathVariable("slideId") String slideId, @PathV
model.addAttribute("currentNumOfSlide", slideIndex + 1);
model.addAttribute("spaceId", spaceId);
model.addAttribute("spaceName", spaceManager.getSpace(spaceId).getName());
model.addAttribute("slideExternalLinkList", slideExternalLinkManager.getLinks(slideId));
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

@@ -16,6 +16,7 @@
import com.fasterxml.jackson.databind.node.ObjectNode;

import edu.asu.diging.vspace.core.exception.ImageCouldNotBeStoredException;
import edu.asu.diging.vspace.core.exception.SlideDoesNotExistException;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

@@ -41,4 +45,10 @@ public ResponseEntity<String> deleteExternalLink(@PathVariable("id") String spac
externalLinkManager.deleteLink(linkId);
return new ResponseEntity<String>(HttpStatus.OK);
}

@RequestMapping(value = "/staff/module/{id}/slide/{slideId}/externallink/{linkId}", method = RequestMethod.DELETE)
public ResponseEntity<String> deleteSlideExternalLink(@PathVariable("id") String moduleId, @PathVariable("slideId") String slideId, @PathVariable("linkId") String linkId) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?


}

public ResponseEntity<String> checkIfSlideExists(ISlideManager slideManager, String id) throws IOException{
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this extra method seems unnecessary

import edu.asu.diging.vspace.core.model.display.ISlideExternalLinkDisplay;

@RunWith(MockitoJUnitRunner.class)
public class SlideExternalLinkDisplayFactoryTest {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

?

@jdamerow jdamerow closed this Oct 22, 2024
@jophals jophals reopened this Oct 31, 2024
@jophals
Copy link
Author

jophals commented Oct 31, 2024

i had do to multiple merges to fix conflicts and diverging

@@ -13,7 +13,7 @@
import edu.asu.diging.vspace.core.services.ISpaceLinkManager;

@Controller
public class DeleteLinkController {
public class DeleteSpaceLinkController {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's not correct, is it?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What do you mean? I renamed it DeleteSpaceLinkController because it was housing methods for deleting module slide links and space links and you didn't want to mix them. So now there's DeleteSpaceLinkController and DeleteSlideLinkController

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

do you want me to just keep the name as DeleteLinkController?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes, this class does not just delete spacelinks, so the name is misleading.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oh okay, got it. I named it that because they all originate from '/staff/space'. But I see what you mean

@@ -78,6 +79,7 @@ public ResponseEntity<Map<String,Object>> showSpaceLinks(@PathVariable String id
Map<String,Object> responseData = new HashMap<String,Object>();
responseData.put("spaceLinks", spaceLinkManager.getLinkDisplays(id));
responseData.put("externalLinks", externalLinkManager.getLinkDisplays(id));
System.out.println("EXTERNAL LINKS 2: " + externalLinkManager.getLinkDisplays(id));
responseData.put("moduleLinks", moduleLinkManager.getLinkDisplays(id));
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove sysouts

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this still

@jdamerow jdamerow closed this Nov 28, 2024
controllers, cleaned up some unused code in slide.html, and removed
comments/print statements
…aces-2.0 into story/VSPC-242

Merging due to mismatch with remote branch
@jophals jophals self-assigned this Dec 13, 2024
@jophals jophals reopened this Dec 13, 2024

@Repository
@JaversSpringDataAuditable
public interface SlideExternalLinkRepository extends PagingAndSortingRepository<ExternalLinkSlide, String> {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This repo is called SlideExternalLinkRepository but the model is called ExternalLinkSlide. Should be consistentn


@Transactional
@Service
public class SlideExternalLinkManager
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same here

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

are you saying that this needs a Javadoc as well or that there is a naming inconsistency similar to above?

}

@Override
public IExternalLinkSlide createExternalLink(String label, String url, String slideId) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

there needs to be javadoc. Most importantly it needs to be documented that this method does not save the external link it creates, or does it?

return success(link.getId(), link.getExternalLink(), title, null, null);
}

public ResponseEntity<String> success(String id, String url, String label, String linkedId, String linkedSlideStatus) throws IOException{
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should not be public.

return new ResponseEntity<>("{'error': 'Slide could not be found.'}", HttpStatus.NOT_FOUND);
}
IExternalLinkSlide link = externalLinkManager.updateExternalLink(title, externalLink, id);
return success(link.getId(), link.getExternalLink(), title, null, null);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

success is only called once, right? here? if so, there is really no need to have the last two parameters if they are always null.

@jdamerow
Copy link
Member

jdamerow commented Jan 6, 2025

also, there are conflicts

@jdamerow jdamerow closed this Jan 6, 2025
@jophals jophals reopened this Jan 6, 2025
jophals and others added 3 commits January 7, 2025 12:21
consistency throughout project, added Javadocs, cleaned up unused
paramters...
…aces-2.0 into story/VSPC-242

needed to merge in order to push new changes
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants