npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

frontflow

v0.0.9

Published

- #### To use this package at max. ```bash npm init ``` - #### Download & install frontflow. ```bash npm i frontflow ``` - #### Make files like `.gitignore` & choose ES-6 syntax.`type` : `module`. Cut Readme file. - #### To run react server . Use command

Downloads

22

Readme

Frontflow

  • To use this package at max.

npm init
  • Download & install frontflow.

npm i frontflow
  • Make files like .gitignore & choose ES-6 syntax.type : module. Cut Readme file.

  • To run react server . Use command

npm run react-dev

# Rules

  • Create-react-app

    • we can import relatively only inside src directory.

  • Fundamentals

    • rfce by typing this in component file , we can get template of component.

    • Variables inside component always enclosed in {}.

    • Component file name be in either .jsx or .js format.

    • We are not using CDN's here, instead we are using npm packages & external webpack.

    • Only 0, false, null ,"" , undefined are considered as false.

    • Imagine DOM as a tree like structure. In this structure if we define state in some component. Then if we have to use it in upper level components, then we have to drill the state to all the way to up.

    • To get rid of this , we define state outside the component in seprate file.

  • Components & props & Events

    • A component name always in capital letters.

    • Components are nothing but regular javascript functions that returns jsx .

    • Jsx is always enclosed in parenthesis () .

    • Inside JSX we cannot use if-else. But we can use {condition ? truthy : falsy} or {condition1 && condition2 ...} or {condition1 || condition2 ...}

    • As conditions are all about uncertainity , so these are enclosed in {}.

    • If multiple statements are true , then && returns last truthy statement. And || returns first truthy staement.

    • props.children is used to fetch children elements passed between parents.

  • Useful functions

// map, slice , unshift , forEach , copy operator.

// 1. ()=> { }  , Always enclose in curly braces if there is no single line
  array.forEach((element)=> {
    total += Number(element.amount) ; 
    if(element.amount >= 0) profit += Number(element.amount) ;
    else loss += Number(element.amount) ;
  }) ;
// 2. Events used with forms
// onSubmit
// onChange with input
// 

// Map function
{blogs.map((element,index) => ()) }
  • Components stylings

    • For css files to work , we need loaders.css-loaders && style-loader

    • CSS Modules are used to style components, which are named as fileName.module.css.

    • In css modules styles are written in form of classes only.

// This way you can include ,multiple classes at once....
<p id="money-plus" className={`${styles.money} ${styles.plus}`}>
  • Hooks

    • 1. useState()

      • If we have to change only 1 property in state. We first have to copy the prevState using [...operator]

      • If we are using setState , we dont have to manually render the component again.

    import {useState} from 'react' ;
    
    const [state, setState] = useState(initialState) ;
    setState(newState) ;
    
    <!-- (e)=>setName(e.target.value) -->
    
    • 2. useRef()

    import {useRef} from 'react' ;
    
    let inputRef = useRef() ;
      
    <input ref = {inputRef} />
    
    const tag = inputRef.current.value ;
    // inputRef.current.focus() ;
    
    • 3. useEffect()

      • All side-effects are performed in this. like fetching data from API, calling DOM methods , etc.

      • For each different task, we can use different useEffect() .

      • only setup function will be executed component is maded & every time component updates.

      • setup function + empty array ,executed once only when component is maded.

      • setup function + array with element , executed when component is maded + everytime when change occur in element.

      • if there is return statement in setup function , that will be executed when component is destroyed.

    import {useEffect} from 'react' ;
    
    useEffect(setup , dependencies) ;
    
    <!-- Fetching data from API -->
      useEffect(() => {
        fetch("https://api.example.com/data")
        .then((response) => response.json())
        .then((data) => setData(data));
    }, []);
    
    <!-- Calling SideEffects -->
    useEffect(() => {
    const timer = setInterval(() => {
        console.log("Timer running");
    }, 1000);
    
    // Cleanup function to clear the interval when the component unmounts
    return () => clearInterval(timer);
    }, []);
    
    <!-- Local Storage uses -->
       useEffect(()=>{
    const email = localStorage.getItem("email");
    if(email){
        setEmail(email);
    }
    },[]);
    
    useEffect(() => {
        localStorage.setItem("email", email);
    },[email]);
    • 4. useReducer()

      • If we are manipulating states using useState in too many event-handlers or functions. Than we can use this hook.

      • reducer is a function made outside our component which contains manipulation of state logic.

    import {useReducer} from 'react' ;
      
    const [state, dispatch] = useReducer(reducer, initialValue) ;
    
    <!-- example -1 -->
    
    const blogsReducer = (state, action) => {
    switch (action.type) {
      case "ADD":
        return [action.blog, ...state];
      case "REMOVE":
        return state.filter((blog, index) => index !== action.index);
      default:
        return [];
    }
    };
    
    const [blogs, dispatch] = useReducer(blogsReducer,[]);
    
    dispatch({type: "ADD", blog: {title:formData.title, content:formData.content}});
    
    • 5. useCustom()

    • 6. Context-API

      • First of all create context in a seprate file.

      • Then provide the context. Create context will return 2 values consumer & provider

      • Consume the context.

    import { createContext, useContext} from "react";
    
    // 1. Created a context
    export const customContext = createContext() ;
    
    export function CustomItemContext(props)
    {
        <!-- Set all states here & use them here that is manipulate them here -->
    
    
        <!-- After making and manipulating all states we return in end -->
    
    
        <!-- 2. Provide context  -->
        return (
            <customContext.Provider value={{total,items,handleAdd,handleRemove,reset,toggleCart,cart,clear}}>
                {showCart &&  <CartModal/>}
                {children}
            </customContext.Provider>
        );
    }
    
    <!-- 3. Use that context -->
    export function useValue()
    {
        const value = useContext(customContext) ;
        return value;
    }
    
    <!-- 4. How to use in components -->
    
    <CustomItemContext>
        <Navbar />
        <Items />
    </CustomItemContext>
    
    <!-- 5. Then in Navbar & Items , we can simply fetch states like this -->
    function Navbar() {
    const {total,items,reset,toggleCart} = useValue();
    }
  • Routing

    • Routing provides different URL addresses in SPA without a new page.

  • Redux

  • Events

    • Events are written in tags as attributes. eg. <button onClick = {}> </button>. These can be called in 2 ways.

    • <button onClick = {out}> </button> or <button onClick = {()=>out()}> </button>

    • After occuring of event , we have to manually render the component.

    • If the function that we are calling in variable using this inside it. Then we have to use arrow functionto call it.

    function out(e)
    {
        e.preventDefault() ;
        const tag = e.target ;
          
        const content = {
            inside: e.target.textContent ,
    
        }
    }
    
  • Why react is better ?

    • React uses virtual DOM i.e it dont change the real DOM directly.

    • It only changes that nodes, which are changed.