Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Soren-git/zUI

Folders and files

NameName
Last commit message
Last commit date

Latest commit

History

122 Commits

Repository files navigation

🎮 zUI - Bibliothèque de Menus NUI pour FiveM

💻 Exemple de Code Illustré

local Menu = zUI.CreateMenu("Titre", "Sous-Titre", "Voici la description", nil, "F1", "Ouvrir le Menu exemple.")
local subMenu = zUI.CreateSubMenu(Menu, "Titre", "Sous-Titre", "Voici la description")
local checkboxState = false
local percentage = 0
local index = 1
local colorListIndex = 1
Menu:SetItems(function(Items)
 Items:AddSeparator("Séparateur")
 Items:AddLine()
 Items:AddButton("Titre", "Je suis un bouton", {},
 function(onSelected, onHovered)
 end, subMenu)
 Items:AddLinkButton("Titre", "Je suis un bouton lien", {}, "https://zsquad.fr")
 Items:AddCheckbox("Titre", "Je suis une checkbox", checkboxState, {}, function(onSelected, onHovered)
 if onSelected then
 checkboxState = not checkboxState
 end
 end)
 Items:AddSlider("Titre", "Je suis un slider", percentage, 10, {},
 function(onSelected, onHovered, onChange, percentage)
 if onChange then
 percentage = percentage
 end
 end)
 Items:AddList("Titre", "Je suis une liste", index, { "Item #1", "Item #2" }, {},
 function(onSelected, onHovered, onListChange, i)
 if onListChange then
 index = i
 end
 end)
 Items:AddColorList("Titre", "C'est une liste de couleurs", colorListIndex,
 { "#00ff00", "#fffd2c", "#ff00ff", "#ff0000", "#0000ff" }, {},
 function(onSelected, onHovered, onListChange, index)
 if onListChange then
 colorListIndex = index
 end
 end)
end)
subMenu:SetItems(function(Items)
 Items:AddSeparator("Sous Menu", "right")
 Items:AddLine()
 Items:AddButton("Titre", "Je suis un bouton", {}, function(onSelected, onHovered)
 if onSelected then
 local value = zUI.ShowModal("Titre", {
 { type = "text", name = "Text input", description = "Input description", isRequired = false, minLength = 4, maxLength = 15 },
 { type = "number", name = "Number input", description = "Input description", isRequired = false },
 { type = "checkbox", name = "Checkbox input", description = "Input description", defaultValue = true },
 { type = "colorpicker", name = "Color input", defaultValue = "#faad2c" },
 { type = "date", name = "Date input", format = "DD/MM/YYYY" }
 }, {})
 print(value[1])
 end
 end)
 Items:AddButton("Titre", "Je suis un bouton", {}, function(onSelected, onHovered)
 if onHovered then
 zUI.ShowInfo("Titre", nil, {
 { "Titre", "Valeur" },
 { "Titre", "Valeur" },
 { "Titre", "Valeur" },
 { "Titre", "Valeur" },
 })
 end
 end)
end)
Menu:OnOpen(function()
 print("Menu open")
end)
subMenu:OnOpen(function()
 print("subMenu open")
end)
Menu:OnClose(function()
 print("Menu close")
end)
subMenu:OnClose(function()
 print("subMenu close")
end)
zUI.CreateContext("vehicle", function(Items, coords3D, Entity)
 Items:AddSeparator("vehicle")
end)
zUI.CreateContext("props", function(Items, coords3D, Entity)
 Items:AddSeparator("props")
end)
zUI.CreateContext("ped", function(Items, coords3D, Entity)
 Items:AddSeparator("ped")
end)
zUI.CreateContext("other", function(Items, coords3D, Entity)
 Items:AddSeparator("other")
end)
local coords = vector3(350.46109008789, 932.27905273438, 203.43138122559)
zUI.CreateContext(coords, function(Items, coords3D, Entity)
 Items:AddSeparator("vector")
end)
local withContext = true
Citizen.CreateThread(function()
 while true do
 Wait(0)
 if #(coords - GetEntityCoords(PlayerPedId())) < 3 then
 if withContext then
 zUI.DisplayPulsingNotification("", "", coords, { IsDisabled = true })
 else
 zUI.DisplayPulsingNotification("E", "Intéragir", coords, {})
 if IsControlJustPressed(0, 51) then
 zUI.SendNotification("Titre", "Vous avez appuyer sur E", {},
 "https://i.postimg.cc/jSs6YGNh/ZProject-4.jpg",
 "https://i.postimg.cc/pdrDpzsh/ZBanner-Paypal.png")
 end
 end
 end
 end
end)

🚀 Introduction

zUI est une bibliothèque avancée pour la création de menus NUI dans FiveM. Conçue pour être sobre, optimisée, et visuellement attrayante, elle utilise React pour l'interface utilisateur, tout en vous permettant d'écrire vos scripts en Lua. Inspirée de RageUI, zUI apporte des fonctionnalités modernisées, une expérience utilisateur améliorée et simplifie considérablement l'accès à la création de menus pour les développeurs.

🌟 Caractéristiques Principales

  • 🔧 Simplicité d'Utilisation : Interface claire et intuitive pour une intégration facile dans vos scripts Lua.
  • ⚡ Performance Supérieure : Construit avec des technologies modernes pour des performances optimales.
  • 💻 Interface Moderne : Utilise React pour des menus plus réactifs et fluides.
  • 🎨 Personnalisation Avancée : Ajustez les couleurs, le texte et le comportement des éléments de menu à votre guise.

📋 Installation

1. Cloner le Dépôt

git clone https://github.com/ZProject-Official/zUI.git

2. Installer les Dépendances

Naviguez dans le répertoire cloné et installez les dépendances nécessaires pour React.

  • Veillez à bien avoir Node.js sur votre machine.
cd zUI
cd user-interface
npm install && npm run build

Ou installez la version Release

3. C'est déjà fini !

Félicitations, vous avez terminé l'installation et la configuration de zUI sur votre serveur FiveM ! 🚀

Maintenant que vous avez mis en place les bases, il est temps de vous amuser avec la personnalisation et de rendre vos menus aussi attractifs que fonctionnels.

🛠️ Utilisation

Créer un Menu

Pour créer un menu avec zUI, utilisez la fonction zUI.CreateMenu. Voici un exemple de création de menu :

local Menu = zUI.CreateMenu("Titre", "Sous-Titre", "Voici la description", nil, "F1", "Ouvrir le Menu exemple.")

Ajouter des Éléments au Menu

Une fois le menu créé, vous pouvez ajouter des composants tels que des séparateurs, des lignes colorées, et des boutons interactifs.

Menu:SetItems(function(Items)
 Items:AddSeparator("Séparateur")
 Items:AddLine()
 Items:AddButton("Titre", "Je suis un bouton", {},
 function(onSelected, onHovered)
 end, subMenu)
 Items:AddLinkButton("Titre", "Je suis un bouton lien", {}, "https://zsquad.fr")
 Items:AddCheckbox("Titre", "Je suis une checkbox", checkboxState, {}, function(onSelected, onHovered)
 if onSelected then
 checkboxState = not checkboxState
 end
 end)
 Items:AddSlider("Titre", "Je suis un slider", percentage, 10, {},
 function(onSelected, onHovered, onChange, percentage)
 if onChange then
 percentage = percentage
 end
 end)
 Items:AddList("Titre", "Je suis une liste", index, { "Item #1", "Item #2" }, {},
 function(onSelected, onHovered, onListChange, i)
 if onListChange then
 index = i
 end
 end)
 Items:AddColorList("Titre", "C'est une liste de couleurs", colorListIndex,
 { "#00ff00", "#fffd2c", "#ff00ff", "#ff0000", "#0000ff" }, {},
 function(onSelected, onHovered, onListChange, index)
 if onListChange then
 colorListIndex = index
 end
 end)
end)

FAQ

Q : Comment puis-je changer la touche d'ouverture du menu ?
R : Vous pouvez définir la touche d'ouverture lors de la création du menu via le paramètre dédié, ou via la configuration de votre ressource.

Q : Puis-je utiliser zUI avec d'autres scripts ?
R : Absolument, zUI est conçu pour être entièrement compatible avec d'autres scripts Lua pour FiveM.

📝 Changelog

[v1.0.0] - 2024年08月10日

  • Initial release avec support pour les menus personnalisés et les composants de base.

[v1.0.1] - 2024年08月13日

  • Correction de différents problèmes.

[v1.0.2] - 2024年08月18日

  • Refonte totale de la partie back-end.

[v1.0.3] - 2024年08月23日

  • Ajouts de différentes features (keyboardInput, Closable, OnClose, OnListChange, Arrows, Checkbox Icon, Config).

[v1.0.4] - 2024年08月26日

  • Ajouts de différentes features (AlertInput, Couleurs personnalisés ~#faad2c~, Animations, Scrool de façon smooth, Optimisation de la navigation, Hover configurable, Auto focus dans le keyboardInput).

[v1.0.5] - 2024年09月17日

  • Refonte totale. Ajout de différentes features (HelpNotification, RenderSprite, LinkButton, CloseAll, Theme.json, Badges Personnalisés, Documentation, Optimisation, Position des séparateurs)

[v1.0.6] - 2024年12月05日

  • Refonte totale. Ajout de différentes features (HelpNotification, PulsingNotifications, Notifications, ContextUI, ColorList, Slider, Info, Modal, Themes, ApplyTheme)

📬 Support

Pour toute question ou problème, rejoignez notre Discord.

📜 Licence

Ce projet est sous licence MIT. Voir le fichier LICENSE pour plus de détails.


Merci d'avoir choisi zUI pour vos projets FiveM. Nous espérons que cette bibliothèque vous aidera à créer des menus NUI élégants et performants !

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 66.8%
  • Lua 26.3%
  • CSS 6.7%
  • HTML 0.2%

AltStyle によって変換されたページ (->オリジナル) /