Skip to content

Commit

Permalink
Merge pull request #542 from ita-social-projects/#544_Page_overview_a…
Browse files Browse the repository at this point in the history
…dd_fields

- added fields following #544 task
  • Loading branch information
fortamt authored Aug 12, 2022
2 parents 31aad59 + a9f7008 commit 3cccb44
Show file tree
Hide file tree
Showing 7 changed files with 53 additions and 5 deletions.
10 changes: 9 additions & 1 deletion src/main/java/com/softserveinc/dokazovi/dto/user/UserDTO.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import lombok.Builder;
import lombok.Data;

import java.sql.Timestamp;
import java.util.Set;

/**
Expand All @@ -30,7 +31,11 @@ public class UserDTO {

private String bio;

private String socialNetwork;
private String region;

private String city;

private Set<String> socialNetworks;

private Set<DirectionDTO> directions;

Expand All @@ -40,4 +45,7 @@ public class UserDTO {

private LatestUserPostDTO lastAddedPost;

private Timestamp createdAt;

private Timestamp editedAt;
}
Original file line number Diff line number Diff line change
Expand Up @@ -51,9 +51,6 @@ public class DoctorEntity {
@Column(columnDefinition = "TEXT")
private String bio;

@Column(columnDefinition = "TEXT")
private String socialNetwork;

@ColumnDefault("1.0")
private Double promotionScale;

Expand Down
17 changes: 17 additions & 0 deletions src/main/java/com/softserveinc/dokazovi/entity/UserEntity.java
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,9 @@
import org.hibernate.annotations.CreationTimestamp;

import javax.persistence.CascadeType;
import javax.persistence.CollectionTable;
import javax.persistence.Column;
import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
Expand Down Expand Up @@ -70,6 +72,21 @@ public class UserEntity {
@CreationTimestamp
private Timestamp createdAt;

private Timestamp editedAt;

private String region;

private String city;

@ElementCollection
@CollectionTable(
name = "users_social_networks",
joinColumns = @JoinColumn(name = "user_id"))
@Column(name = "link")
@EqualsAndHashCode.Exclude
@ToString.Exclude
private Set<String> socialNetworks;

@OneToMany(fetch = FetchType.EAGER, mappedBy = "user", cascade = CascadeType.ALL)
@EqualsAndHashCode.Exclude
@ToString.Exclude
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -80,8 +80,9 @@ public interface UserRepository extends JpaRepository<UserEntity, Integer> {
* @return the resulting user entity page
*/
@Query(nativeQuery = true,
value = " SELECT U.* FROM DOCTORS D "
value = " SELECT U.*, SN.LINK FROM DOCTORS D "
+ " JOIN USERS U ON U.USER_ID = D.USER_ID "
+ " JOIN USERS_SOCIAL_NETWORKS SN ON D.USER_ID = SN.USER_ID"
+ " ORDER BY D.PROMOTION_LEVEL DESC, D.RATING DESC, "
+ " U.LAST_NAME, U.FIRST_NAME ")
Page<UserEntity> findDoctorsProfiles(Pageable pageable);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import org.springframework.util.CollectionUtils;

import javax.transaction.Transactional;
import java.sql.Timestamp;
import java.util.Set;
import java.util.UUID;

Expand Down Expand Up @@ -232,6 +233,7 @@ public UserEntity update(UserEntity user) {
if (user != null) {
UserEntity oldUser = getById(user.getId());
if (oldUser != null) {
user.setEditedAt(new Timestamp(System.currentTimeMillis()));
return userRepository.save(user);
}
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
alter table public.users
add column EDITED_AT timestamp;

create table if not exists USERS_SOCIAL_NETWORKS(
user_id integer not null
constraint social_networks_user_id_fkey
references users,
link varchar
);

insert into USERS_SOCIAL_NETWORKS (user_id, link)
select user_id, social_network from DOCTORS;

alter table public.doctors
drop column social_network;

alter table public.users
add column REGION varchar;

alter table public.users
add column CITY varchar;
Original file line number Diff line number Diff line change
Expand Up @@ -440,8 +440,10 @@ void updateUserEntityTest() {
UserEntity userEntity = userService.getById(1);
userEntity.setEmail(expectedEmail);
when(userRepository.save(any(UserEntity.class))).thenReturn(expected);
Assertions.assertNull(expected.getEditedAt());
UserEntity actual = userService.update(userEntity);
Assertions.assertEquals(expectedEmail, actual.getEmail());
Assertions.assertNotNull(actual.getEditedAt());
}

@Test
Expand Down

0 comments on commit 3cccb44

Please sign in to comment.