Description du programme

Application web de gestion et d'édition de timeway pour installations de traitement de surface (galvanoplastie, phosphatation, etc.).

Version : 2.1.0 — © 2026 VK Vision SA


Description

VKTimeway permet de définir, visualiser et éditer graphiquement les cycles de transfert d'un ou de plusieurs robots sur une ligne de traitement de surface. L'application gère :


Architecture

Application PWA vanilla JS sans framework, fonctionnant entièrement côté client.

App/
├── index.html                  Point d'entrée unique (SPA)
├── manifest.json               Manifeste PWA
├── sw.js                       Service Worker (cache offline)
└── assets/
    ├── js/
    │   ├── VKApp.js            Routeur SPA + logique de toutes les pages
    │   ├── VKModels.js         Constructeurs des modèles de données
    │   ├── VKData.js           Persistance localStorage
    │   ├── VKDiagram.js        Moteur de rendu canvas du timeway
    │   ├── VKTimewayGen.js     Générateur automatique de timeway
    │   ├── VKReport.js         Génération de rapports PDF (pdfmake)
    │   ├── VKI18n.js           Internationalisation (FR / EN / DE / ZH)
    │   ├── pdfmake.min.js      Librairie PDF (embarquée, offline)
    │   └── vfs_fonts.min.js    Polices pdfmake (Roboto, embarquées)
    ├── css/
    │   └── app.css             Styles spécifiques à l'application
    └── img/
        └── icons/              Icônes PNG de la barre d'outils de l'éditeur

Modules JS

Fichier Rôle
VKApp.js Routeur hash (#/, #/machines, …), rendu des pages, modales d'édition, simulateur
VKModels.js Constructeurs Machine, Version, Position, Hoist, Sequence, Timeway, …
VKData.js Lecture / écriture dans localStorage
VKDiagram.js Rendu canvas : axes, étapes, aides visuelles, détection collision
VKTimewayGen.js Génération automatique d'un timeway depuis une séquence
VKReport.js Rapports PDF via pdfmake : machine, séquence, timeway, diagramme
VKI18n.js Dictionnaire quadrilingue + injection dans le DOM (data-i18n)

Modèle de données

Machine                  Id, Name, Number, Client, Location, Remarks, CreatedAt, UpdatedAt
└── Version[]            Id, Number, Comment, Remarks, CreatedAt, UpdatedAt
    ├── Positions[]      id, name, flag, group, tank, address, branch, lift, lower, distance
    ├── Hoists[]         id, pi, pf, width, front, back, speed1 (mm/s), accdec (ms), lifts[], lowers[]
    ├── Sequences[]      id, name, remarks, steps[]
    ├── Timeways[]       id, name, remarks, cycletime (ms), visible, steps[]
    ├── LiftTypes[]      10 types de montée nommés (id, name, time)
    └── LowerTypes[]     10 types de descente nommés (id, name, time)

Toutes les données sont stockées en JSON dans localStorage sous les clés tw_machines et tw_versions.


Fonctionnalités principales

Gestion des machines

Export / Import des données

Versions

Positions, robots (hoists), séquences

Types montées / descentes

Génération automatique de timeway

Éditeur graphique de timeway

Simulateur de production

Rapports PDF

Générés côté client via pdfmake (aucun serveur requis, fonctionne offline). Chaque rapport est téléchargé directement en .pdf.

Rapport Déclencheur Contenu
Fiche machine Bouton dans l'onglet Positions Positions · Robots · Types montées/descentes · Remarques
Fiche séquence Bouton par ligne dans l'onglet Séquences Étapes (position, groupe, montée, descente, Tmin/Tmax/Tégouttage) · Remarques
Fiche timeway Bouton par ligne dans l'onglet Timeway Étapes avec tous les temps (Ti, Tf, Tégouttage, Tmontée, Tdescente, Ttransfert) · Remarques
Rapport diagramme Bouton dans la toolbar de l'éditeur Capture du canvas + table des étapes · Remarques (orientation paysage si nécessaire)

Structure commune des rapports :


Internationalisation

Quatre langues supportées : Français (défaut), English, Deutsch, 中文 (chinois simplifié).

La langue est sélectionnable depuis la page d'accueil et persistée dans localStorage. Le changement est instantané sans rechargement de page.

Utilisation dans le HTML : data-i18n="clé" sur n'importe quel élément. Utilisation dans le JS : VKI18n.t('clé').


Installation / Démarrage

Développement

Aucune dépendance serveur. L'application fonctionne directement depuis un navigateur.

  1. Cloner le dépôt
  2. Servir le dossier App/ via un serveur HTTP local (requis pour le Service Worker) :
    npx serve App/
    # ou
    python -m http.server 8080 --directory App/
    
  3. Ouvrir http://localhost:8080 dans un navigateur moderne

Note : L'ouverture directe du fichier index.html (file://) ne fonctionnera pas avec le Service Worker. Un serveur HTTP est nécessaire.

Build de distribution (version minifiée)

Un script de build génère une version optimisée dans Dist/ :

npm install       # une seule fois
npm run build     # génère Dist/

Le build effectue :

Important : Incrémenter SW_CACHE_VERSION dans build.js à chaque nouveau déploiement pour forcer la mise à jour du cache chez les utilisateurs.

Pour servir la version de distribution :

npx serve Dist/

Dépendances front-end (embarquées)

Librairie Version Usage
Bootstrap 5.x UI composants, grille, modales
Font Awesome 6.x Icônes vectorielles
pdfmake 0.2.10 Génération de rapports PDF côté client

Toutes les dépendances sont incluses dans App/assets/ — aucune connexion CDN requise.

Dépendances de build (développement uniquement)

Package Usage
terser Minification JavaScript
clean-css Minification CSS
fs-extra Opérations fichiers avancées

Structure des routes

Hash Page
#/ Accueil (sélection de langue, export/import données)
#/machines Liste des machines
#/machines/create Nouvelle machine
#/machines/:id Détail machine + liste des versions
#/machines/:id/version/:vid Édition d'une version (positions, robots, séquences, timeway)

Versioning de l'application

La version est définie par la constante VK_VERSION en tête de VKApp.js :

var VK_VERSION = 'ver. 2.1.0';

Elle s'affiche automatiquement dans le footer de l'application et est intégrée dans les métadonnées et les noms de fichiers des rapports PDF générés.


Revision #5
Created 2026-03-24 09:25:49 UTC by Jean-Noël Voirol
Updated 2026-03-24 09:42:36 UTC by Jean-Noël Voirol