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)
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.
- 🔧 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.
git clone https://github.com/ZProject-Official/zUI.git
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
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.
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.")
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)
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.
- Initial release avec support pour les menus personnalisés et les composants de base.
- Correction de différents problèmes.
- Refonte totale de la partie back-end.
- Ajouts de différentes features (keyboardInput, Closable, OnClose, OnListChange, Arrows, Checkbox Icon, Config).
- 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).
- Refonte totale. Ajout de différentes features (HelpNotification, RenderSprite, LinkButton, CloseAll, Theme.json, Badges Personnalisés, Documentation, Optimisation, Position des séparateurs)
- Refonte totale. Ajout de différentes features (HelpNotification, PulsingNotifications, Notifications, ContextUI, ColorList, Slider, Info, Modal, Themes, ApplyTheme)
Pour toute question ou problème, rejoignez notre Discord.
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 !