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

gatsby-atomic-block

v0.2.5

Published

Gatsby Atomic Block is the platform web creators choose to build professional GatsbyJS HTML, plus CSS basic elements such as paragraph, heading, iamge, link and much more, with sanitize method.

Downloads

5

Readme

  • [v.0.1.x:next]: Recode AB output. Normalize package.
  • [v.0.x.0:warning]: The first grand finale release will be publish at v1.0.0.
  • [v.0.1.0:update]: Very first release atempt; package core system stable.


Gatsby Atomic Block

LAYOUT BUILDER by Edu4Dev

Engine Agent: Gatsby - Javascript Framework

Engine SubAgent: Gatsby Plugin

Gatsby Plugin Name: Gatsby Atomic Block

Author: Edu4Dev - Milton Bolonha

Description: Gatsby Atomic Block is the platform web creators choose to mount professional coomponents to GatsbyJS, using one atomic block you have attributes as paragraph, heading, image, link, carousel, columns, fontColor and much more, with sanitize method.

*Keep in mind these bundle aren't a block builder.


Plugin URI: https://www.npmjs.com/package/gatsby-atomic-block

Plugin Install: npm i gatsby-atomic-block

Version: 0.2.0

Year: 2021

Invoke Atomic Block in your custom component:

// Place your Atomic Block inside your own custom Block
// Do that using the Gatsby Block Builder Standard
<AtomicBlock
	// Types BLOCK or MODAL, should modal removed nope?
	type={`BLOCK`}

	// blockTitle={`your var goes here`}
	// alignTo={`your var goes here`}
	// backgroundColor={`your var #hex here`}

	// Need to change to right name in sliderClass
	// I will switch sliderClass to blockClass
	// sliderClass={`your var goes here`}

	// Emmet::block::AtomicBlock[numColumns=3]
	// Emmet::pseudo_output::Layout*3>AtomicBlock*3
	// Example: 
	//  <Layout numColumns={3} >
	//   <AtomicBlock numColumns={3} />
	// </Layout>
	// numColumns={`your var goes here`}

	// Internal and External http.links
	// Output::a[href="https://external"]
	// or
	// Output::<Link to="/internal-page-link" />
	// Automatic switch not coded
	// link={`your var goes here`}
	// linkText={`your var goes here`}

	// Echo/Print Heading <h$> sanitized
	// heading={`your var goes here`}
	// Heading importance not coded yet
	// Heading importance 10 = <h1>
	// Heading importance 9 = <h2>
	// Heading importance 8 = <h3>
	// Heading importance 7 = <h4>
	// Heading importance 6 = <h5>
	// Heading importance 5 = <h6>
	// headingImportance={10}
	// Notice, use <Layout type="MAIN" /> to
	// wrapper your heading schema
	// <Layout type="MAIN" /> not available yet
	// on gatsby-layout-builder v.0.1.7

	// Echo/Print Paragraph <p> sanitized
	// paragraph={`your var goes here`}

	// Img's
	// srcSet={`your var goes here`}
	// sizes={`your var goes here`}
	// src={`your var goes here`}
	// Every image must have an alternative text
	// alt={`your var goes here`}

	// Forms has id and the <form> > <code>
	// formID={`your var goes here`}
	// Doesn't need to use <form>
	// Gatsby will ever output an 100% static files
	// To use form actions you must server this in a right manner
	// To do that, use Meli.sh or Netlify Serverless
	// form={`your var goes here`}

	// Default: false == Default: columns
	// isCarousel={false}

	// not available yet
	// fontColor={`#000`}
	// fontSize={14}

	// Display canvas block infos for each ABlock
	// canvas.atomic-block.infos{
  //   position; styles; childs; plain_texts;
	// } 
	// debug={false}
>
	// Your paramaters will be outputed in here
	// Your content goes here
	// {children}
</AtomicBlock>

Inside the Atomic Block we do have the main elements to be used on the construction of your custom block.

You should use <AtomicBlock /> as many as you can, combine it with the Gatsby Layout Builder plugin.

// Below you can view each type of output components
// subAgent's are elements.children's
// comes from inside <AtomicBlock>{children}</AtomicBlock>
// type BLOCK
<ABblockcontainer
	subAgent={subAgent}
	params={params}
	contents={contents}
	configs={configs}
/>
// type MODAL should (yes) I remove modal from AB?
<ABmodalcontainer
	data={data}
	subAgent={subAgent}
	contents={contents}
/>
// type::BLOCK_or_MODAL::img
<ABimg
	elementClass={elementClass}
	srcSet={contents.srcSet}
	sizes={contents.sizes}
	src={contents.src}
	alt={alt}
/>
// type::BLOCK_or_MODAL::h$
<ABheading
	elementClass={elementClass}
	heading={contents.heading}
	fontSize={contents.fontSize}
	fontColor={contents.fontColor}
/>
// type::BLOCK_or_MODAL::p
<ABparagraph
	elementClass={elementClass}
	paragraph={contents.paragraph}
/>
// type::BLOCK_or_MODAL::a_or_Link
<ABlink
	elementClass={elementClass}
	link={contents.link}
	linkText={contents.linkText}
/>
// type::BLOCK_or_MODAL::form without action must be normalize
<ABform name={formName} formId={contents.formID} form={contents.form} />

🚀 Quick start

To get started to invoke rows, columns, modals, header and footer wrapper standard structure on your theme, you can follow these steps:

  1. Install Gatsby Atomic Block plugin with:
npm i gatsby-atomic-block

If you already have customize your gatsby-config.js, you can use it. Otherwise, you should create a new gatsby-config.js file to setting your plugin.

  1. Add the Gatsby Layout plugin to the build. In your gatsby-config.js insert the code:
module.exports = {
	plugins: [`gatsby-atomic-block`],
	// if you just have the plugins array
	// you may need to place the plugin string name
	// between the right objects and arrays
	//
}

The Gatsby Atomic Block can you be used in your normal Gatsby ambient. Something like this:

/in-your-gatsby-website
├── ./src/components
├──── ComponentX.js
├── ./src/pages
├──── index.js
└── Gatsby-config.js

/gatsby-business-in-build
├── index.js
├── package.json
└── README.md

Those types who accept subAgent parameter may be used as wrapper of some children element.

  1. Dependencies
	{
		"dependencies":{
			"gatsby": "^4.1.0",
			"gatsby-layout-builder": "^0.1.7",
			"gatsby-plugin-image": "^2.1.0",
			"react": "^17.0.2",
			"react-dom": "^17.0.2",
			"react-icons": "^4.3.1",
			"sass": "^1.43.4"
	},
  	"devDependencies": {
    	"prettier": "^2.4.1"
  }}

🧐 What's inside?

/nu-module
├── element_structure
├── element_logics
├── element_styles
├── configs
├── persistent_vars
├── tools
├── root_files
├── wrapper_gatsby
├── room.code-workspace
└── README.md

🎓 Learning Gatsby

If you're looking for more guidance on plugins, how they work, or what their role is in the Gatsby ecosystem, check out some of these resources: