1.0.56 • Published 1 year ago

@rom13/genius-browser v1.0.56

Weekly downloads
-
License
ISC
Repository
-
Last release
1 year ago

Genius JS (Browser Version)

Installation

Pour utiliser Genius-browser il suffit d'ajouter le script dans votre html.

<script src="https://unpkg.com/@rom13/genius-browser@1.0.56/index.js"></script>

Attention pour éviter tout soucis, ne mettez pas le script en defer..

Création d'un Genius :

Dans votre script créez une variable comme ceci :

const genius = $;

Il vous suffit désormais d'utiliser les fonctions du Genius

Genius.date()

return la date formaté en français

let date = genius.date();
console.log(date); // return = 30/05/2022

Genius.heure()

return l'heure correctement formaté

let heure = genius.heure();
console.log(heure); // return = 00:04

let heurecomplete = genius.heure("complet");
console.log(heurecomplete); // return = 00:04:02

Genius.nbaleatoire(maximum)

return un nombre aleatoire entre 1 et le nombre maximum (inclu !)

let nombre = genius.nbaleatoire(12);
console.log(nombre); // return = 1 ou 2 ou 3........ou 12 !

Genius.nbaleatoireminmax(minimum,maximum)

return un nombre aleatoire entre le nombre minimum et le nombre maximum (inclu !)

let nombre = genius.nbaleatoireminmax(0, 24);
console.log(nombre); // return = 0 ou 1 ou 2........ou 24 !

Genius.recupnb(string,transformer)

Récupère uniquement les nombres d'un string et return le résultat Transforme le résultat en type number (optionnel)

let mot = "Le 34 c'est le sud";
console.log(genius.recupnb(mot)); // log 34

genius.recupnb(mot); // return 34 (type string)
genius.recupnb(mot, "transformer"); // return 34 (type number)

Genius.recupsommeObjet(option)

return la somme des propriétés d'un objet

const objet = {
  nom: "rom",
  nombre: 13,
  hobbie: "art",
  code: 34,
};

console.log(genius.recupsommeObjet(objet, "string"));
// ici on additionne les propriétés et on renvoi une version string
// return => rom 13 art 34
console.log(genius.recupsommeObjet(objet, "number"));
// ici on additionne les nombres entres eux et on renvoi la somme (type number)
// return 47 (13+34)

Genius.moyenne(nb1,nb2,nb3,nb4,nb5,nb6,nb7,nb8,nb9,nb10)

Return la moyenne arrondi au centième près 2 nombres minimum, jusqu'à 10 nombres (optionnel)

let moyenne = genius.moyenne(11, 11, 15, 18);
console.log(moyenne); // log 13.75

Genius.bigmoyenne(tableau)

Return la moyenne arrondi au centième près nombres illimités (array)

let nb = [12, 12, 12, 45];
console.log(genius.bigmoyenne(nb)); // return 20.25

Genius.pourcent(valeurmax,indice,option)

Return le pourcentage de l'indice par rapport à votre valeur max

genius.pourcent(500, 250);
// return 50 (type number)
genius.pourcent(500, 250, "string");
// return 50% (type string)
genius.pourcent(500, 250, "log");
// return 50 (type number) et log => 250 représente 50% de 500(100%)

Genius.ristournePourcent(prix,ristourne,option)

Return le montant final après une ristoure en %

ristournePourcent(150, 75);
// return 37.5 (type number)

ristournePourcent(150, 75, "log");
// return 37.5 (type number)
// et log => La ristourne à réduit le prix initial de 150 à 37.5 !

Genius.intervallesecondes(secondes, fonction)

Créer un interval en secondes, et lance la fonction à chaques intervalles.

function perso() {
  console.log("je suis un intervalle ! hihi");
}
OU;
const perso = () => {
  console.log("je suis un intervalle ! hihi");
};

genius.intervallesecondes(1, perso); // log toutes les secondes (je suis un intervalle ! hihi)

Genius.intervalleminutes(minutes, fonction)

Créer un interval en minutes, et lance la fonction à chaques intervalles.

function perso() {
  console.log("je suis un intervalle ! hihi");
}

genius.intervalleminutes(1, perso); // log toutes les minutes (je suis un intervalle ! hihi)

Genius.timeursecondes(secondes, fonction)

Créer un timer en secondes, avant d'executer la fonction.

function perso() {
  console.log("je suis un timer ! hoho");
}

genius.timeursecondes(5, perso); // log après 5 secondes (je suis un timer ! hoho)

Genius.timeurminutes(minutes, fonction)

Créer un timer en minutes, avant d'executer la fonction.

function perso() {
  console.log("je suis un timer ! hoho");
}

genius.timeurminutes(2, perso); // log après 2 minutes (je suis un timer ! hoho)

Genius.chronolog(debut)

Créer un chrono qui s'affiche en console, qui débute par le nombre choisi. Si aucun nombre est choisi il commencera par 1.

genius.chronolog(); // log = 1 PUIS console.log = 2 PUIS console.log = 3 ....etc chaques secondes

genius.chronolog(6); // log = 6 PUIS console.log = 7 PUIS console.log = 8 ....etc chaques secondes

genius.chronologstop(); // stop le chrono

genius.timeursecondes(5, genius.chronologstop); // exemple avec genius.timeursecondes, au bout de 5 secondes le chrono est stopppé.

Genius.purifierstring(string)

Nettoie un string qui contient des charactères spéciaux.

let string = "Hey $je su'is un s*tring$$ avec ple)ins de symbo@les biza%rres^^ hihi.";

console.log(genius.purifierstring(string)); // return : Hey je suis un string avec pleins de symboles bizarres hihi.
console.log(genius.purifierstring(3)); // return : erreur

if (genius.purifierstring(EXEMPLE) === "erreur") {
  // exemple de condition
  // On sait que la valeur donné n'est pas un type string
}

Genius.fusionObjet(objet1,objet2,objet3,objet4,objet5,objet6,objet7,objet8,objet9,objet10)

return un objet issu de la fusion de plusieurs objets (2 objets minium), jusqu'à 10 objets (otpionnel)

let fiche = { nom: "Romain", ville: "Montpellier" };
let fiche2 = { nom: "Allane", taille: "1m80" };
console.log(fusionObjet(fiche, fiche2)); // return => { nom: 'Allane', ville: 'Montpellier', taille:'1m80 }

ATTENTION si les objets possèdent une Keyproperty identique (dans l'exemple => 'nom' ) la valeur de la propriété sera celle du denier objet passé en paramètre.

Genius.csscolor()

Créer un code css aléatoire de couleur

let color = genius.csscolor(); // return rgb(7,89,171) EXEMPLE

Genius.fetchlog(url,fonction)

Log la response de l'url, et lance la fonction après (optionnel)

function mafonction() {
  // code de votre fonction
}
genius.fetchlog("https://API.com");
// log response.data

genius.fetchlog("https://API.com", mafonction);
// log response.data puis execute la fonction

Genius.get(url)

Récupère la réponse d'un requête GET

genius
  .get("https://MONURL")
  .then((response) => {
    console.log(response);
    // Affiche les données renvoyées par le serveur
  })
  .catch((error) => {
    console.error(error);
    // Affiche l'erreur s'il y en a une
  });

Genius.post(url,objet)

Post l'objet et récupère la réponse

let objet = { pseudo: "Genius", pass: "00000" };

genius
  .post("https://MONURL", objet)
  .then((response) => {
    console.log(response);
    // Affiche les données renvoyées par le serveur
  })
  .catch((error) => {
    console.error(error);
    // Affiche l'erreur s'il y en a une
  });

Genius.salaireSMIC(heures,option,log)

return ou log (optionnel) le salaire au SMIC arrondi

genius.salaireSMIC(35, "brut"); // return 1646
genius.salaireSMIC(35, "net"); // return 1304

genius.salaireSMIC(35, "brut", "log");
// log => Pour 35 heures, le salaire sera de 1646 euros (Brut)
genius.salaireSMIC(35, "net", "log");
// log => Pour 35 heures, le salaire sera de 1304 euros (Net)

Genius.compareTAB(tab1,tab2,option)

return ou log (optionnel) si deux tableaux sont identiques

Javascript renvoi false si on compare deux tableaux au contenu identique. Gebius.compareTAB renvoi true

let tab = ["1", { prenom: "tom", age: 18, tab: ["r", 5, { age: 11 }] }, "5", ["1", 2]];
let tab2 = ["1", { prenom: "tom", age: 18, tab: ["r", 5, { age: 11 }] }, "5", ["1", 2]];

genius.compareTAB(tab, tab2);
// return true
genius.compareTAB(tab, tab2, "log");
// log => Vrai, les tableaux sont identiques

Genius.trierNum(tab,option,log)

return ou log (optionnel) les valeurs d'un tableau, trié (nombres uniquement)

fonctionne avec le type string et number

let tab = ["6", 2, "3", "1", 4, "5"];

genius.trierNum(tab, "croissant");
// return [ '1', 2, '3', 4, '5', '6' ]
genius.trierNum(tab, "décroissant");
// return [ '6', '5', 4, '3', 2, '1' ]
genius.trierNum(tab, "croissant", "log");
// return et log => [ '1', 2, '3', 4, '5', '6' ]

Genius.sansDoublon(tab,log)

return ou log (optionnel) les valeurs d'un tableau sans doublon

let tab2 = ["rom", "sana", "jean", "sana", 4, 4, "rom"];

genius.sansDoublon(tab);
// return [ 'rom', 'sana', 'jean', 4 ]
genius.sansDoublon(tab, "log");
// return et log => [ 'rom', 'sana', 'jean', 4 ]

Genius.textContent(valeur,selector,style)

Modifie le contenu (textcontent) et le style (optionnel) de votre élément HTML

<p id="text"></p>; // votre élément HTML (exemple)

let styledate = "font-size:35px;background-color:black;color:orange;text-align:center";
// le style voulu (optionnel)

genius.textContent(genius.date(), "#text", styledate);
// exemple avec Genius.date()

genius.textContent(genius.date(), "#text");
// Le style étant optionnel, vous pouvez juste modifier la valeur

Exemple rendu avec le style :

ASTUCE : Afficher une heure dynamique

Utilisation de Genius.textContent() + Genius.heure() + requestAnimationFrame()

//on créer la fonction
function heureDynamique() {
  genius.textContent(genius.heure("complet"), "#text");
  requestAnimationFrame(heureDynamique);
}

//on appel "l'animation"
requestAnimationFrame(heureDynamique);

Resultat : Votre heure est dynamique, elle se met à jour sans rechargement !

Genius.element(type,classId,style)

Créer l'élément HTML, lui ajoute la classe ou l'id (optionnel), et lui applique le style (optionnel)

let style = `color:red;`;

let element = genius.element("p", "#test", style);
// ATTENTION le style donné par la fonction est prioritaire
// si l'ID test possède une color:yellow dans votre css, l'element aura la color:red donné par le style !

let element = genius.element("p", "#test");
// Le style étant optionnel, vous pouvez faire ceci

let element = genius.element("p", "", style);
// Si vous souhaitez mettre un style sans mettre la classe ou l'id

Genius.event(selector,event,callback,once)

Créer un évènement sur l'élément HTML lance la fonction callback

Possibilité d'activer l'event une seule fois si once est précisé

<button id="bouttontest">boutton</button>;
// votre élément HTML (exemple)

function callback(e) {
  console.log(e.target.textContent); // log => 'boutton'

  // ATTENTION CETTE FONCTION EST LA CALLBACK
  // Elle ne peut prendre que (e) en paramètre
  // Si vous souhaitez appeler des fonctions avec vos propres paramètres
  // Insèrez les dans cette fonction
}

genius.event("#bouttontest", "click", callback);
// On créer un écouteur au click sur l'element

// OU

genius.event("#bouttontest", "click", (e) => {
  console.log(e.target.textContent); // log => 'boutton'
  // Inserez vos fonctions...
});
// Avec once
genius.event("#bouttontest", "click", callback, "once");
// OU
genius.event(
  "#bouttontest",
  "click",
  (e) => {
    console.log(e.target.textContent); // log => 'boutton'
    // Inserez vos fonctions...
  },
  "once"
);

Enjoy :sunglasses:

1.0.55

1 year ago

1.0.54

1 year ago

1.0.53

1 year ago

1.0.56

1 year ago

1.0.49

2 years ago

1.0.51

2 years ago

1.0.50

2 years ago

1.0.52

2 years ago

1.0.29

2 years ago

1.0.28

2 years ago

1.0.33

2 years ago

1.0.32

2 years ago

1.0.31

2 years ago

1.0.30

2 years ago

1.0.37

2 years ago

1.0.36

2 years ago

1.0.35

2 years ago

1.0.34

2 years ago

1.0.39

2 years ago

1.0.38

2 years ago

1.0.40

2 years ago

1.0.44

2 years ago

1.0.43

2 years ago

1.0.42

2 years ago

1.0.41

2 years ago

1.0.48

2 years ago

1.0.47

2 years ago

1.0.46

2 years ago

1.0.45

2 years ago

1.0.27

2 years ago

1.0.26

2 years ago

1.0.25

2 years ago

1.0.24

2 years ago

1.0.23

2 years ago

1.0.22

2 years ago

1.0.21

2 years ago

1.0.20

2 years ago

1.0.19

2 years ago

1.0.18

2 years ago

1.0.17

2 years ago

1.0.16

2 years ago

1.0.15

2 years ago

1.0.14

2 years ago

1.0.13

2 years ago

1.0.12

2 years ago

1.0.11

2 years ago

1.0.10

2 years ago

1.0.9

2 years ago

1.0.8

2 years ago

1.0.7

2 years ago

1.0.6

2 years ago

1.0.5

2 years ago

1.0.4

2 years ago

1.0.3

2 years ago

1.0.2

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago