Post in 3 parts : 1 French - 2 English - and 3 code
Poste en 3 sections : 1 Français, 2 Anglais, 3 Le code à la fin.
French
Hier, j'ai testé CLAUD pour tenter de réussir à faire un formulaire qui me permettrait de distribuer mes R.O.I liquides vers les jarres
Le but, comme vous le voyez sur l'image, c'est de rentrer le nom d'un compte.
Il affiche alors les soldes en hive et en en hbd.
Il propose ensuite de rentrer un montant dans l'une des deux devises, sans dépasser le solde.
Et distribue ensuite, en une commande hivekeychain selon les 6 jarres. Les 10% restants sont a envoyer au compte entré plus haut.
Quand je dis transfert, j'entends PowerUp pour les hive et en épargne pour les HBD.
Il m'a fait un formulaire qui je trouve tout à fait acceptable, mais il n'interagit pas avec #hivekeychain.
Je vais donc devoir encore travailler dessus, a repris ce formulaire et s'en est fait une version, en utilisant deepseek au lieu de Claud, chez lui les soldes s'affichent bien ce qui est un progrès déjà par rapport à mon formulaire. Et chez lui hivekeychain est censé être utilisé mais sont formulaire répond qu'il ne le détecte pas.
Il nous reste donc encore du travail à faire, mais je suis déjà impressionné par ce que quelques mots en prompt ont pu donner comme résultat.
Si quelqu'un veut nous aider, avec un code qui ferait cela, si possible documenté pour me permettre d'apprendre, j'en serais bien entendu très content
English
Yesterday, I tested CLAUD in an attempt to create a form that would allow me to distribute my liquid R.O.I. to the jars.
The aim, as you can see from the image, is to enter the name of an account.
It then displays the hive and hbd balances.
It then suggests entering an amount in one of the two currencies, without exceeding the balance.
It then distributes the 6 jars in a order. The remaining 10% is sent to the account entered above.
When I say transfer, I mean PowerUp for hive and savings for HBD.
He made me a form that I find quite acceptable, but it doesn't interact with hivekeychain.
So I'm going to have to work on it some more, has taken this form and made a version for himself, using deepseek instead of Claud, with him the balances display well, which is already an improvement over my form. And with him, hivekeychain is supposed to be used, but his form says it doesn't detect it.
So we still have some work to do, but I'm already impressed by what a few words in prompt can achieve.
If anyone would like to help us out, with some code that would do this, if possible documented so that I can learn, I'd of course be delighted.
I admit , for once, I translated with DeepL.com (free version).
The code
Warning, this is a one prompt try, it gave results, but not what I wanted, it needs lots of rework.
Attention, c'est un essai en un "prompt", il y a eu du résultat, mais pas tout ce qui fut désiré, et donc à besoin de corriger beaucoup de choses.
language HTML - Javascript
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Calculateur de transferts Hive</title>
<style>
body {
font-family: Arial, sans-serif;
max-width: 800px;
margin: 0 auto;
padding: 20px;
background-color: #f5f5f5;
}
.container {
background-color: #fff;
border-radius: 8px;
padding: 20px;
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}
h1 {
color: #1a5099;
text-align: center;
}
.balance-info {
display: flex;
justify-content: space-between;
margin-bottom: 20px;
padding: 15px;
background-color: #f0f7ff;
border-radius: 6px;
border-left: 5px solid #1a5099;
}
.balance-item {
display: flex;
flex-direction: column;
align-items: center;
}
.balance-value {
font-size: 24px;
font-weight: bold;
color: #1a5099;
}
.balance-label {
font-size: 14px;
color: #666;
}
.form-group {
margin-bottom: 15px;
}
label {
display: block;
margin-bottom: 5px;
font-weight: bold;
}
input[type="text"],
input[type="number"] {
width: 100%;
padding: 10px;
border: 1px solid #ddd;
border-radius: 4px;
box-sizing: border-box;
}
.currency-selector {
display: flex;
gap: 10px;
margin-bottom: 20px;
}
.currency-btn {
flex: 1;
padding: 10px;
background-color: #eee;
border: 1px solid #ddd;
border-radius: 4px;
cursor: pointer;
}
.currency-btn.active {
background-color: #1a5099;
color: white;
border-color: #0d4b8c;
}
.transfers-table {
width: 100%;
border-collapse: collapse;
margin-bottom: 20px;
}
.transfers-table th,
.transfers-table td {
padding: 10px;
text-align: left;
border-bottom: 1px solid #ddd;
}
.transfers-table th {
background-color: #f5f5f5;
}
.transfers-table tr:last-child td {
font-weight: bold;
background-color: #f0f7ff;
}
button {
display: block;
width: 100%;
padding: 12px;
background-color: #1a5099;
color: white;
border: none;
border-radius: 4px;
font-size: 16px;
cursor: pointer;
margin-top: 20px;
}
button:hover {
background-color: #0d4b8c;
}
.result {
margin-top: 20px;
padding: 15px;
background-color: #f8f9fa;
border-radius: 4px;
border-left: 5px solid #28a745;
}
pre {
background-color: #f1f1f1;
padding: 15px;
border-radius: 4px;
overflow-x: auto;
white-space: pre-wrap;
}
.error {
color: #dc3545;
margin-top: 10px;
}
.hidden {
display: none;
}
</style>
</head>
<body>
<div class="container">
<h1>Calculateur de transferts Hive</h1>
<div class="balance-info">
<div class="balance-item">
<span class="balance-value" id="hiveBalance">0.000</span>
<span class="balance-label">HIVE</span>
</div>
<div class="balance-item">
<span class="balance-value" id="hbdBalance">0.000</span>
<span class="balance-label">HBD</span>
</div>
</div>
<div class="form-group">
<label for="username">Votre nom d'utilisateur Hive:
utilisateur">
checkBalance">Vérifier mon solde
currency-selector">
currency-btn active" id="hiveBtn">HIVE
currency-btn" id="hbdBtn">HBD
form-group">
amount">Montant à distribuer:
number" id="amount" step="0.001" min="0" placeholder="Entrez le montant">
transfers
-table">
Destinataire
Pourcentage
Montant
@itharagaian.cha
5%
amount1 ">0.000
@itharagaian.edu
10%
amount2 ">0.000
@itharagaian.fun
10%
amount3 ">0.000
@itharagaian.uns
10%
amount4 ">0.000
@introversion
55%
amount5 ">0.000
Montant restant
10%
amountRemaining ">0.000
generateJson">Générer la commande JSON
result hidden" id="resultContainer">
Commande JSON générée:
jsonResult
">
errorMessage" class="error hidden">
document.addEventListener('DOMContentLoaded', function() { const username = document.getElementById('username'); const checkBalanceBtn = document.getElementById('checkBalance'); const hiveBalanceEl = document.getElementById('hiveBalance'); const hbdBalanceEl = document.getElementById('hbdBalance'); const hiveBtn = document.getElementById('hiveBtn'); const hbdBtn = document.getElementById('hbdBtn'); const amountInput = document.getElementById('amount'); const generateJsonBtn = document.getElementById('generateJson'); const jsonResult = document.getElementById('jsonResult'); const resultContainer = document.getElementById('resultContainer'); const errorMessage = document.getElementById('errorMessage'); let selectedCurrency = 'HIVE'; let userBalance = { hive: 0, hbd: 0 }; // Currency selection hiveBtn.addEventListener('click', function() { hiveBtn.classList.add('active'); hbdBtn.classList.remove('active'); selectedCurrency = 'HIVE'; calculateAmounts(); }); hbdBtn.addEventListener('click', function() { hbdBtn.classList.add('active'); hiveBtn.classList.remove('active'); selectedCurrency = 'HBD'; calculateAmounts(); }); // Check balance checkBalanceBtn.addEventListener('click', function() { const user = username.value.trim(); if (!user) { showError("Veuillez entrer un nom d'utilisateur"); return; } fetchHiveBalance(user); }); // Calculate on amount change amountInput.addEventListener('input', calculateAmounts); // Generate JSON generateJsonBtn.addEventListener('click', generateJson); function fetchHiveBalance(user) { showError(""); // API endpoint for getting account information const api = "https://api.hive.blog"; fetch(api, { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({ jsonrpc: "2.0", method: "condenser_api.get_accounts", params: [[user]], id: 1 }) }) .then(response => response.json()) .then(data => { if (data.result && data.result.length > 0) { const account = data.result[0]; userBalance.hive = parseFloat(account.balance); userBalance.hbd = parseFloat(account.hbd_balance); hiveBalanceEl.textContent = userBalance.hive.toFixed(3); hbdBalanceEl.textContent = userBalance.hbd.toFixed(3); } else { showError("Utilisateur non trouvé"); } }) .catch(error => { showError("Erreur lors de la récupération du solde: " + error.message); }); } function calculateAmounts() { const amount = parseFloat(amountInput.value) || 0; // Calculate amounts based on percentages const amount1 = amount * 0.05; // 5% pourBest regards,
≋𝕴𝖙𝖍𝖆𝖗𝖆 𝕲𝖆ï𝖆𝖓≋ Prince of Principality of Bastion
≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋≋
Discord : https://discord.principalityofbastion.org
Website : https://meta-etre.com / https://nft.bastion.city
Social Networks: See on our website.
Founder of the Principality of Bastion