New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@atomic-layout/core

Package Overview
Dependencies
Maintainers
1
Versions
13
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@atomic-layout/core - npm Package Compare versions

Comparing version 0.12.0-alpha.0 to 0.12.0

lib/utils/functions/omit/index.d.ts

6

lib/const/props.d.ts

@@ -36,2 +36,8 @@ import { Numeric } from './defaultOptions';

/**
* Order to lay out an item in a flex or grid container.
* @css `order`
* @see https://developer.mozilla.org/en-US/docs/Web/CSS/order
*/
order?: number | CSSGlobalValues;
/**
* Aligns flex items of the current flex.

@@ -38,0 +44,0 @@ * @css `align-self`

3

lib/index.js

@@ -237,2 +237,5 @@ 'use strict';

},
order: {
props: ['order'],
},
align: {

@@ -239,0 +242,0 @@ props: ['align-self'],

4

package.json
{
"name": "@atomic-layout/core",
"description": "Atomic Layout core module",
"version": "0.12.0-alpha.0",
"version": "0.12.0",
"license": "MIT",

@@ -54,3 +54,3 @@ "main": "lib/index.js",

],
"gitHead": "45736df16e1680b682968325ba819e4700c67777"
"gitHead": "e3422ade0bc19401cd129811e0c5b30fa9a51e69"
}

@@ -5,6 +5,70 @@ [![Package version](https://img.shields.io/npm/v/@atomic-layout/core.svg)](https://npmjs.com/package/@atomic-layout/core)

Core functionality of the [Atomic Layout][atomic-layout] library.
[Atomic Layout][atomic-layout] core library.
> **Please note that as a user of Atomic Layout you are not supposed to use this package directly in your application.** It serves as a logic abstraction for various rendering implementations (with styled-components, emotion, etc.). Use this package if you are planning to introduce a new rendering implementation of Atomic Layout.
> **Please note that as a user of Atomic Layout you are not supposed to use this package directly in your application.** It serves as a logic abstraction for various rendering implementations (with styled-components, emotion, etc.). Use this package if you are planning to introduce a new styling implementation of Atomic Layout.
[atomic-layout]: https://github.com/kettanaito/atomic-layout
## Motivation
Atomic Layout contains its core functionality in a separate module in order to reuse it for various styling implementations (`styled-components`, `emotion`, etc.). The logic distributed in this module is style-agnostic and mainly concerns calculations and transformations of data structures used by the library. It also provides common type definitions to be used by Atomic Layout, or its consumers.
## Scope
Atomic Layout core operates under the following scope:
### Layout interface
- `Layout` instance to be exposed by each individual styling implementation of the library
- Interface to consume layout options (`defaultUnit`, `breakpoints`, etc.)
- Interface to store the provided options and reference them
### Breakpoint transformation
- Breakpoint parsing (`getAreaRecords`)
- Breakpoint transformations (`mergeBreakpoints`, `openBreakpoint`, `closeBreakpoint`)
- Breakpoint compiling (`createMediaQuery`)
### Media Query handling
- Normalization of media queries (`normalizeMediaQuery`)
### Utilities
- String utilities (i.e. `toCammelCase`, `toLowerCaseFirst`)
- Math utilities (i.e. `transformNumeric`)
- Functional utilities (i.e. `compose`, `when`, `memoizeWith`)
## Type definitions
> Refer to the complete type definition module `atomic-layout/core/lib/index.d.ts`.
The common use case to access the types exported by this package is to provide a proper type annotation to your custom React components that accept the same props as the library's components do (`Box`, `Composition`, `Only`, etc.).
Here's an example of how to annotate a custom React component that accepts all the props that the `Box` component does:
```tsx
import * as React from 'react'
import { BoxProps } from 'atomic-layout/core'
const MyComponent: React.FC<BoxProps & MyComponentProps> = ({
children,
...boxProps
}) => {
return <Box {...boxProps}>{children}</Box>
}
```
## Contributing
### Fork the repository
Fork this repository using the "Fork" button on the top right of the [repository page](https://github.com/kettanaito/atomic-layout/tree/master/packages/atomic-layout-core).
### Follow Git workflow
Please follow the [Git workflow](https://github.com/kettanaito/atomic-layout/blob/master/.github/CONTRIBUTING.md#git-workflow) described in the contribution guidelines to the original library.
## License
MIT.
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc