This commit is contained in:
aespin 2024-10-07 10:25:25 +02:00
parent 88ae0f6c1f
commit 5bb93812ab
10 changed files with 208 additions and 22 deletions

34
Makefile Normal file
View File

@ -0,0 +1,34 @@
# Variables
IMAGE_NAME = registry.espin.casa/cml04-falcon-ui
CONTAINER_NAME = cml04-falcon-ui
# Check if Docker or Podman is available
DOCKER := $(shell command -v docker 2> /dev/null)
PODMAN := $(shell command -v podman 2> /dev/null)
# Determine which command to use based on availability
ifdef DOCKER
DOCKER_CMD := docker
else ifdef PODMAN
DOCKER_CMD := podman
else
$(error "Neither Docker nor Podman is installed on this system.")
endif
# Build the Docker image
build:
$(DOCKER_CMD) build -t $(IMAGE_NAME) -f docker/Dockerfile .
# Run the container
run:
@templ generate
@$(DOCKER_CMD) run $(IMAGE_NAME)
# Stop and remove the container
stop:
$(DOCKER_CMD) stop $(CONTAINER_NAME)
$(DOCKER_CMD) rm $(CONTAINER_NAME)
# Remove the Docker image
clean:
$(DOCKER_CMD) rmi $(IMAGE_NAME)

View File

@ -1,9 +1,12 @@
$(document).ready(function () {
// Initialize all input of date type.
const calendar = bulmaCalendar.attach('[type="date"]',{type:"datetime",isRange:true,color:"link",minuteSteps:1});
const calendar = bulmaCalendar.attach('[type="date"]',{
weekStart: 1,
dateFormat: 'dd/MM/yyyy',
type:"datetime",
isRange:true,
color:"link",
minuteSteps:1});
// To access to bulmaCalendar instance of an element
$('#submit').click(function() {
const dateInput = $('#inicio').val();

28
celsa2048.crt Normal file
View File

@ -0,0 +1,28 @@
-----BEGIN CERTIFICATE-----
MIIE0zCCA7ugAwIBAgIJANu+mC2Jt3uTMA0GCSqGSIb3DQEBCwUAMIGhMQswCQYD
VQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTERMA8GA1UEBxMIU2FuIEpvc2Ux
FTATBgNVBAoTDFpzY2FsZXIgSW5jLjEVMBMGA1UECxMMWnNjYWxlciBJbmMuMRgw
FgYDVQQDEw9ac2NhbGVyIFJvb3QgQ0ExIjAgBgkqhkiG9w0BCQEWE3N1cHBvcnRA
enNjYWxlci5jb20wHhcNMTQxMjE5MDAyNzU1WhcNNDIwNTA2MDAyNzU1WjCBoTEL
MAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExETAPBgNVBAcTCFNhbiBK
b3NlMRUwEwYDVQQKEwxac2NhbGVyIEluYy4xFTATBgNVBAsTDFpzY2FsZXIgSW5j
LjEYMBYGA1UEAxMPWnNjYWxlciBSb290IENBMSIwIAYJKoZIhvcNAQkBFhNzdXBw
b3J0QHpzY2FsZXIuY29tMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA
qT7STSxZRTgEFFf6doHajSc1vk5jmzmM6BWuOo044EsaTc9eVEV/HjH/1DWzZtcr
fTj+ni205apMTlKBW3UYR+lyLHQ9FoZiDXYXK8poKSV5+Tm0Vls/5Kb8mkhVVqv7
LgYEmvEY7HPY+i1nEGZCa46ZXCOohJ0mBEtB9JVlpDIO+nN0hUMAYYdZ1KZWCMNf
5J/aTZiShsorN2A38iSOhdd+mcRM4iNL3gsLu99XhKnRqKoHeH83lVdfu1XBeoQz
z5V6gA3kbRvhDwoIlTBeMa5l4yRdJAfdpkbFzqiwSgNdhbxTHnYYorDzKfr2rEFM
dsMU0DHdeAZf711+1CunuQIDAQABo4IBCjCCAQYwHQYDVR0OBBYEFLm33UrNww4M
hp1d3+wcBGnFTpjfMIHWBgNVHSMEgc4wgcuAFLm33UrNww4Mhp1d3+wcBGnFTpjf
oYGnpIGkMIGhMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTERMA8G
A1UEBxMIU2FuIEpvc2UxFTATBgNVBAoTDFpzY2FsZXIgSW5jLjEVMBMGA1UECxMM
WnNjYWxlciBJbmMuMRgwFgYDVQQDEw9ac2NhbGVyIFJvb3QgQ0ExIjAgBgkqhkiG
9w0BCQEWE3N1cHBvcnRAenNjYWxlci5jb22CCQDbvpgtibd7kzAMBgNVHRMEBTAD
AQH/MA0GCSqGSIb3DQEBCwUAA4IBAQAw0NdJh8w3NsJu4KHuVZUrmZgIohnTm0j+
RTmYQ9IKA/pvxAcA6K1i/LO+Bt+tCX+C0yxqB8qzuo+4vAzoY5JEBhyhBhf1uK+P
/WVWFZN/+hTgpSbZgzUEnWQG2gOVd24msex+0Sr7hyr9vn6OueH+jj+vCMiAm5+u
kd7lLvJsBu3AO3jGWVLyPkS3i6Gf+rwAp1OsRrv3WnbkYcFf9xjuaf4z0hRCrLN2
xFNjavxrHmsH8jPHVvgc1VD0Opja0l/BRVauTrUaoW6tE+wFG5rEcPGS80jjHK4S
pB5iDj2mUZH1T8lzYtuZy0ZPirxmtsk3135+CKNa2OCAhhFjE0xd
-----END CERTIFICATE-----

38
docker/Dockerfile Normal file
View File

@ -0,0 +1,38 @@
# Etapa de compilación
FROM golang:1.23.1-bookworm AS builder
ENV TZ=Europe/Madrid
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
ADD celsa2048.crt /usr/local/share/ca-certificates/celsa2048.crt
RUN chmod 644 /usr/local/share/ca-certificates/celsa2048.crt
RUN apt-get update \
&& apt-get install -y --no-install-recommends ca-certificates
RUN update-ca-certificates
WORKDIR /app
COPY . .
RUN go get -d -v ./...
RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -mod=mod -ldflags "-s -w" -o cml04-falcon-system main.go
# Etapa de producción
FROM debian:stable
ENV TZ=Europe/Madrid
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
ADD celsa2048.crt /usr/local/share/ca-certificates/celsa2048.crt
RUN chmod 644 /usr/local/share/ca-certificates/celsa2048.crt
RUN apt-get update \
&& apt-get install -y --no-install-recommends ca-certificates
ADD assets /root/assets
ADD templates /root/templates
RUN update-ca-certificates
WORKDIR /root/
COPY --from=builder /app/cml04-falcon-system .
CMD ["./cml04-falcon-ui"]

View File

@ -1,20 +1,82 @@
package handlers
import (
"fmt"
"net/http"
"strings"
"text/template"
"git.espin.casa/albert/cml04-falcon-ui/storage"
"git.espin.casa/albert/cml04-falcon-ui/types"
"github.com/julienschmidt/httprouter"
)
func BarcodesHandler(storage storage.Storager) httprouter.Handle {
return func(w http.ResponseWriter, r *http.Request, ps httprouter.Params) {
t, _ := template.ParseFiles("templates/base.html", "templates/barcodes.html")
err := t.Execute(w, nil)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
// get method
if r.Method == http.MethodGet {
// parse template files
t, _ := template.ParseFiles("templates/base.html", "templates/barcodes.html")
// execute templates
err := t.Execute(w, nil)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
}
// post method
if r.Method == http.MethodPost {
// barcodes holder
barcodes := []types.Barcode{}
// parse form data from formulary
if err := r.ParseForm(); err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
}
// barcode
codigo := r.FormValue("codigo")
// date range
fechas := r.FormValue("fechas")
// loading bed
evacuadores := r.FormValue("evacuadores")
// check form values
if codigo != "" {
// call storager
data, err := storage.Barcode(r.Context(), codigo)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
// append barcode to holder
barcodes = append(barcodes, *data)
} else {
inicio := strings.Split(fechas, "-")[0]
inicio = strings.TrimSpace(inicio)
final := strings.Split(fechas, "-")[1]
final = strings.TrimSpace(final)
// get loading bed from string
lb, ok := types.MapLoadingBed[evacuadores]
// if loading bed not found
if !ok {
http.Error(w, fmt.Errorf("loading bed value not found").Error(), http.StatusInternalServerError)
return
}
// call storager
data, err := storage.ListBarcode(r.Context(), lb, inicio, final)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
//set barcodes
barcodes = data
}
// parse template files
t, _ := template.ParseFiles("templates/base.html", "templates/barcodes.html")
// execute templates
err := t.Execute(w, barcodes)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
}
}
}

View File

@ -14,6 +14,7 @@ func CreateRoutes(r *httprouter.Router, storage storage.Storager) {
r.GET("/bcp", handlers.BCPHandler(storage))
r.GET("/lcp", handlers.LCPHandler(storage))
r.GET("/barcodes", handlers.BarcodesHandler(storage))
r.POST("/barcodes", handlers.BarcodesHandler(storage))
r.GET("/labels", handlers.LabelsHandler())
r.GET("/standards", handlers.StandardsHandler(storage))
r.GET("/bundle", handlers.BundleHandler(storage))

View File

@ -2,6 +2,7 @@ package storage
import (
"context"
"fmt"
"git.espin.casa/albert/cml04-falcon-ui/types"
)
@ -27,12 +28,14 @@ func (s *storage) Bundle(ctx context.Context, ua string) (bundle *types.BundleDa
// ListBarcode implements Storager.
func (s *storage) ListBarcode(ctx context.Context, lb types.LoadingBed, inicio string, final string) (barcodes []types.Barcode, err error) {
panic("unimplemented")
fmt.Println(lb, inicio, final)
return []types.Barcode{}, nil
}
// Barcode implements Storager.
func (s *storage) Barcode(ctx context.Context, reading string) (barcode *types.Barcode, err error) {
panic("unimplemented")
fmt.Println(reading)
return &types.Barcode{}, nil
}
func New() Storager {

View File

@ -39,14 +39,25 @@
<div class="column">
<nav class="panel is-link">
<p class="panel-heading"><i class="far fa-file"></i> Listar códigos leídos</p>
<form action="/barcodes">
<form action="/barcodes" method="post">
<div class="panel-block">
<div class="field">
<label class="label">Código barras</label>
<div class="control">
<p class="control has-icons-left">
<input class="input is-link has-dropdown is-hoverable has-icons-right" type="text"
id="codigo" name="codigo" minlength="10" maxlength="10"/>
</p>
</div>
</div>
</div>
<div class="panel-block">
<div class="field">
<label class="label">Fechas</label>
<div class="control">
<p class="control has-icons-left">
<input class="input is-link has-dropdown is-hoverable has-icons-right" type="date"
id="inicio" name="inicio" required/>
id="fechas" name="fechas" required/>
</p>
</div>
</div>
@ -57,7 +68,7 @@
<div class="control">
<p class="control has-icons-left">
<div class="select">
<select name="evacuadores" id="evacuadores" required>
<select name="evacuadores" id="evacuadores">
<option value="3">TODOS</option>
<option value="1">ATA12</option>
<option value="2">ATA345</option>

View File

@ -32,7 +32,7 @@
</ul>
<p class="menu-label">Etiquetas</p>
<ul class="menu-list">
<li><a href="/labels">Ultimas etiquetas</a></li>
<li><a href="/labels">Últimas etiquetas</a></li>
</ul>
</aside>
</div>
@ -43,15 +43,15 @@
<table class="table">
<thead>
<tr>
<th>Unidad de almacén</th>
<th>Evacuador de origen</th>
<th><abbr title="Unidad de almacén">UA</abbr></th>
<th>Origen</th>
<th>Fecha</th>
</tr>
</thead>
<tfoot>
<tr>
<th>Unidad de almacén</th>
<th>Evacuador de origen</th>
<th><abbr title="Unidad de almacén">UA</abbr></th>
<th>Origen</th>
<th>Fecha</th>
</tr>
</tfoot>
@ -112,9 +112,9 @@
</tfoot>
<tbody>
<tr>
<td>9402555315</td>
<td>131620</td>
<td>40160750</td>
<td><a href="">9402555315</a></td>
<td><a href="">131620</a> </td>
<td><a href="">40160750</a></td>
<td>CE253242</td>
<td>S 275 JR +AR</td>
<td>BB01-140X12.1</td>

View File

@ -16,6 +16,12 @@ const (
ALL
)
var MapLoadingBed = map[string]LoadingBed{
"1": ATA12,
"2": ATA345,
"3": ALL,
}
type Barcode struct {
Barcode string `gorm:"primaryKey"`
LoadingBed LoadingBed