Perfil-Personal-Administrativo-Documentacion #26
@ -10,6 +10,7 @@ public abstract class BaseEntity {
|
||||
@Id
|
||||
@GeneratedValue(strategy = GenerationType.UUID)
|
||||
private UUID id;
|
||||
private Employee.Status status;
|
||||
private String fileName;
|
||||
@Lob
|
||||
@Column(columnDefinition = "BLOB")
|
||||
@ -62,4 +63,12 @@ public abstract class BaseEntity {
|
||||
public DocumentType getDocumentType() {
|
||||
return documentType;
|
||||
}
|
||||
|
||||
public void setStatus(Employee.Status status) {
|
||||
this.status = status;
|
||||
}
|
||||
|
||||
public Employee.Status getStatus() {
|
||||
return status;
|
||||
}
|
||||
}
|
||||
|
@ -25,5 +25,11 @@ public enum DocumentType {
|
||||
HUMAN_RESOURCES_GUIDELINES,
|
||||
ADMINISTRATION_FUNCTIONS_MANUAL,
|
||||
ENGINEERING_FUNCTIONS_MANUAL,
|
||||
GENERAL_LABOR_LAW,
|
||||
SUPREME_DECREE,
|
||||
REGULATORY_RESOLUTION,
|
||||
COMPLEMENTARY_REGULATION,
|
||||
HEALTH_SAFETY_LAW,
|
||||
INTERNSHIP_RULES,
|
||||
OTHER
|
||||
}
|
||||
|
@ -1,18 +1,17 @@
|
||||
package com.primefactorsolutions.model;
|
||||
import jakarta.persistence.*;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
package com.primefactorsolutions.model;
|
||||
import jakarta.persistence.*;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
import java.time.LocalDate;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
@Data
|
||||
@Entity
|
||||
@AllArgsConstructor
|
||||
@NoArgsConstructor
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
public class Employee extends BaseEntity {
|
||||
@Data
|
||||
@Entity
|
||||
@AllArgsConstructor
|
||||
@NoArgsConstructor
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
public class Employee extends BaseEntity {
|
||||
private String userName;
|
||||
private String firstName;
|
||||
private String lastName;
|
||||
@ -43,10 +42,4 @@
|
||||
WIDOWED,
|
||||
DIVORCED
|
||||
}
|
||||
public Status getStatus() {
|
||||
return status;
|
||||
}
|
||||
public void setStatus(final Status status) {
|
||||
this.status = status;
|
||||
}
|
||||
}
|
||||
}
|
@ -47,12 +47,6 @@ public class EmployeesListView extends Main {
|
||||
setupPagingGrid();
|
||||
}
|
||||
|
||||
private void updateEmployeeStatus(final Employee employee, final boolean isActive) {
|
||||
employee.setStatus(isActive ? Employee.Status.ACTIVE : Employee.Status.INACTIVE);
|
||||
employeeService.createOrUpdate(employee);
|
||||
refreshGrid();
|
||||
}
|
||||
|
||||
private void addEditButtonColumn(final String label, final ButtonClickHandler handler) {
|
||||
table.addComponentColumn(employee -> createButton(label, () -> handler.handle(employee)));
|
||||
}
|
||||
|
@ -1,16 +1,181 @@
|
||||
package com.primefactorsolutions.views;
|
||||
|
||||
import com.primefactorsolutions.model.Document;
|
||||
import com.primefactorsolutions.model.DocumentType;
|
||||
import com.primefactorsolutions.service.DocumentService;
|
||||
import com.vaadin.flow.component.Component;
|
||||
import com.vaadin.flow.component.button.Button;
|
||||
import com.vaadin.flow.component.dialog.Dialog;
|
||||
import com.vaadin.flow.component.html.Div;
|
||||
import com.vaadin.flow.component.html.H2;
|
||||
import com.vaadin.flow.component.html.IFrame;
|
||||
import com.vaadin.flow.component.html.Main;
|
||||
import com.vaadin.flow.component.notification.Notification;
|
||||
import com.vaadin.flow.component.orderedlayout.FlexComponent;
|
||||
import com.vaadin.flow.component.orderedlayout.HorizontalLayout;
|
||||
import com.vaadin.flow.component.orderedlayout.VerticalLayout;
|
||||
import com.vaadin.flow.component.upload.Upload;
|
||||
import com.vaadin.flow.component.upload.receivers.MemoryBuffer;
|
||||
import com.vaadin.flow.router.PageTitle;
|
||||
import com.vaadin.flow.router.Route;
|
||||
import com.vaadin.flow.spring.annotation.SpringComponent;
|
||||
import jakarta.annotation.security.PermitAll;
|
||||
import org.springframework.context.annotation.Scope;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.Base64;
|
||||
|
||||
@SpringComponent
|
||||
@PermitAll
|
||||
@Scope("prototype")
|
||||
@PageTitle("GovernmentDocumentsView")
|
||||
@Route(value = "/government-documents/me", layout = MainLayout.class)
|
||||
public class GovernmentDocumentsView extends Main {
|
||||
private final DocumentService documentService;
|
||||
private final MemoryBuffer buffer = new MemoryBuffer();
|
||||
private String lastUploadedFileName = null;
|
||||
|
||||
public GovernmentDocumentsView(final DocumentService documentService) {
|
||||
this.documentService = documentService;
|
||||
initializeLayout();
|
||||
}
|
||||
|
||||
private void initializeLayout() {
|
||||
add(createRow(
|
||||
"General Labor Law", DocumentType.GENERAL_LABOR_LAW,
|
||||
"Supreme Decrees", DocumentType.SUPREME_DECREE
|
||||
));
|
||||
|
||||
add(createRow(
|
||||
"Regulatory Resolutions/Provisions", DocumentType.REGULATORY_RESOLUTION,
|
||||
"Complementary Regulations", DocumentType.COMPLEMENTARY_REGULATION
|
||||
));
|
||||
|
||||
add(createRow(
|
||||
"General Law on Hygiene, Health, Occupational Safety, and Well-being", DocumentType.HEALTH_SAFETY_LAW,
|
||||
"Regulatory Framework for Internship Development", DocumentType.INTERNSHIP_RULES
|
||||
));
|
||||
}
|
||||
|
||||
private HorizontalLayout createRow(
|
||||
final String title1,
|
||||
final DocumentType type1,
|
||||
final String title2,
|
||||
final DocumentType type2) {
|
||||
|
||||
HorizontalLayout row = new HorizontalLayout();
|
||||
row.add(
|
||||
createDocumentSection(title1, type1),
|
||||
createDocumentSection(title2, type2)
|
||||
);
|
||||
return row;
|
||||
}
|
||||
|
||||
private Div createDocumentSection(final String title, final DocumentType documentType) {
|
||||
Div section = new Div();
|
||||
section.add(new H2(title));
|
||||
|
||||
Upload upload = createUploadComponent();
|
||||
Button viewButton = createViewButton(documentType);
|
||||
Button saveButton = createSaveButton(viewButton, documentType);
|
||||
|
||||
section.add(createLayout(upload),
|
||||
createLayout(viewButton, new Button("Edit"), saveButton),
|
||||
createAdditionalButtons());
|
||||
return section;
|
||||
}
|
||||
|
||||
private Upload createUploadComponent() {
|
||||
Upload upload = new Upload(buffer);
|
||||
upload.setMaxFiles(1);
|
||||
upload.setAcceptedFileTypes(".pdf");
|
||||
upload.addSucceededListener(event -> handleUploadSuccess(event.getFileName()));
|
||||
return upload;
|
||||
}
|
||||
|
||||
private Button createViewButton(final DocumentType documentType) {
|
||||
Button viewButton = new Button("View");
|
||||
viewButton.setEnabled(documentExists(documentType));
|
||||
viewButton.addClickListener(event -> viewDocument(documentType));
|
||||
return viewButton;
|
||||
}
|
||||
|
||||
private Button createSaveButton(final Button viewButton, final DocumentType documentType) {
|
||||
Button saveButton = new Button("Save");
|
||||
saveButton.addClickListener(event -> saveFile(documentType, viewButton));
|
||||
return saveButton;
|
||||
}
|
||||
|
||||
private void handleUploadSuccess(final String fileName) {
|
||||
lastUploadedFileName = fileName;
|
||||
Notification.show("File uploaded successfully");
|
||||
}
|
||||
|
||||
private HorizontalLayout createLayout(final Component... components) {
|
||||
if (components.length != 1 && components.length != 3) {
|
||||
throw new IllegalArgumentException("This method only accepts 1 or 3 components.");
|
||||
}
|
||||
HorizontalLayout layout = new HorizontalLayout(components);
|
||||
layout.setJustifyContentMode(FlexComponent.JustifyContentMode.CENTER);
|
||||
return layout;
|
||||
}
|
||||
|
||||
private HorizontalLayout createAdditionalButtons() {
|
||||
return createLayout(new Button("Print"), new Button("Download"), new Button("Delete"));
|
||||
}
|
||||
|
||||
private void saveFile(final DocumentType documentType, final Button viewButton) {
|
||||
if (lastUploadedFileName == null) {
|
||||
Notification.show("Please upload a file first.");
|
||||
return;
|
||||
}
|
||||
try {
|
||||
byte[] content = buffer.getInputStream().readAllBytes();
|
||||
documentService.saveDocument(new Document(lastUploadedFileName, documentType, content));
|
||||
Notification.show("File saved successfully.");
|
||||
viewButton.setEnabled(true);
|
||||
} catch (IOException e) {
|
||||
Notification.show("Error saving file: " + e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
private boolean documentExists(final DocumentType documentType) {
|
||||
return documentService.getAllDocuments().stream()
|
||||
.anyMatch(doc -> doc.getDocumentType() == documentType);
|
||||
}
|
||||
|
||||
private void viewDocument(final DocumentType documentType) {
|
||||
documentService.getAllDocuments().stream()
|
||||
.filter(doc -> doc.getDocumentType() == documentType)
|
||||
.findFirst()
|
||||
.ifPresentOrElse(this::showPdfDialog, () -> Notification.show("Document not found."));
|
||||
}
|
||||
|
||||
private void showPdfDialog(final Document document) {
|
||||
Dialog dialog = createDialog(document.getFileData());
|
||||
dialog.open();
|
||||
}
|
||||
|
||||
private Dialog createDialog(final byte[] fileData) {
|
||||
Dialog dialog = new Dialog();
|
||||
dialog.setModal(true);
|
||||
dialog.setCloseOnEsc(true);
|
||||
dialog.setCloseOnOutsideClick(true);
|
||||
|
||||
IFrame pdfFrame = new IFrame();
|
||||
pdfFrame.setSrc(createPdfResource(fileData));
|
||||
pdfFrame.setWidth("800px");
|
||||
pdfFrame.setHeight("600px");
|
||||
|
||||
Button closeButton = new Button("Close", event -> dialog.close());
|
||||
VerticalLayout layout = new VerticalLayout(pdfFrame, closeButton);
|
||||
layout.setAlignItems(FlexComponent.Alignment.CENTER);
|
||||
|
||||
dialog.add(layout);
|
||||
return dialog;
|
||||
}
|
||||
|
||||
private String createPdfResource(final byte[] fileData) {
|
||||
return "data:application/pdf;base64," + Base64.getEncoder().encodeToString(fileData);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user