Security News
Weekly Downloads Now Available in npm Package Search Results
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.
Svelte library for programmatically crafting grid based SVG icons.
Requires Svelte version 4.
Fork, pillage, and plunder! Do whatever as long as you adhere to the project's permissive MIT license.
P45
The core class supplied to P45 components. It provides the context for P45 components such as grid size and certain named nodes.
It also provides functions for parsing command and transformation lists used by components such as <Shape>
and <Transform>
.
class P45 {
// Accepts size of the grid used as the unscaled width and height in pixels.
// Size must be between 8 and 64.
// Size must be divisible by 2.
constructor(size=24) {
this.size = size
this.center // '12' for default size
this.centerNode // 'M12' for default size
this.topLeftNode
this.topCenterNode
this.topRightNode
this.centerLeftNode
this.centerCenterNode
this.centerRightNode
this.bottomLeftNode
this.bottomCenterNode
this.bottomRightNode
}
// Parses nodes such as `M12` into coordinates such as `{ x: 12, y: 12 }`.
parseNode(node);
// Converts coordinates such as `x=12` and `y=12` into nodes such as `M12`.
nodeOf(x, y);
// Converts the number `n` into it's base 26 alphabetic representation.
numberToAlpha(n);
// Parses a string or array of strings representing
// draw commands for a single shape and returns a
// string used in SVG paths like this `<path d={result} />`.
parseDrawCommands(commands);
// Parses a string or array of strings representing
// transform commands for a single element and returns a
// string used for the SVG transform attribute like this
// `<path transform={result} />` or `<g transform={result} />`.
parseTransformCommands(commands);
}
<script>
import { P45, Icon, Shape } from 'p45'
const p45 = new P45()
</script>
<Icon {p45} width="300" height="300">
<!-- Simple triangle -->
<Shape
draw="
move to E20
line to U20
line to M4
close
" />
</Icon>
Illustration of the above drawing but with some minor modifications so it's visible on GitHub and other platforms.
move to <node>
M 3 3
M 12 8
line to <node>
L 3 3
L 12 8
[cubic] curve to <node> control with <node> [and <node>]
S 3 3 12 8
C 3 3 6 6 12 8
(quad|quadratic) curve to <node> [control with <node>]
T 12 8
Q 3 3 12 8
arc to <node> with radius <number> and <number> [and rotation <number>] [and is large] [and is sweeping]
A 6 10 0 0 0 12 8
A 6 10 45 0 0 12 8
A 6 10 0 1 0 12 8
A 6 10 0 0 1 12 8
A 6 10 45 1 1 12 8
close
(connects the ends of the shape together)
z
move by <number>
translate(3 3)
translate(12 8)
move <direction> by <number>
translate(0 -3)
translate(0 3)
translate(-3 0)
translate(3 0)
rotate by <number> [around <node>]
rotate(45)
rotate(45, 12, 8)
scale [x|y] by <number>
scale(2 2)
scale(2 0)
scale(0 2)
scale [x|y|width|height|horizontally|vertically] by <number>
scale(2 2)
scale(2 1)
scale(1 2)
flip [x|y|width|height|horizontally|vertically]
scale(-1 -1)
scale(-1 1)
scale(1 -1)
skew [x|y|width|height|horizontally|vertically] by <number>
skewX(20) skewY(20)
skewX(20)
skewY(20)
<Circle>
Creates a circle from a center origin and radius.
<script>
// P45 instance to use as grid and context.
export let p45 = getContext('p45')
// Circle center point.
export let origin = p45.centerNode
// Circle radius.
export let radius = p45.center - 1
</script>
<!-- Any elements allowable within a `<circle>`. -->
<slot />
<Circle
p45={getContext('p45')}
origin={p45.centerNode}
radius={p45.center - 1}
>
<div />
</Circle>
<Icon>
Container for slotted shapes that form an Icon.
It's represented by an svg element sized by the passed P45 instance. Raw svg child elements maybe slotted in too.
<script>
// An instance of the P45 class.
export let p45 = getContext('p45')
// The icon's title applied using the SVG title tag.
export let title = ""
// Description of the icon applied using the SVG description tag.
export let description = ""
// P45 instance used to size the icon and parse nodes.
setContext("p45", ...)
</script>
<!-- SVG elments and components that form the icon. -->
<slot />
<Icon
p45={getContext('p45')}
title=""
description=""
>
<div />
</Icon>
<Mask>
Creates a referencable mask for cutting holes in other shapes.
<script>
// P45 instance to use as grid and context.
export let p45 = getContext('p45')
// Unique ID to reference the mask.
export let id
</script>
<!-- Elments and components that form the hole in the referencing shape. -->
<slot />
<Mask
p45={getContext('p45')}
id
>
<div />
</Mask>
<RegularPolygon>
Creates a regular polygon from an origin center point, number of edges, and radius to a vertex.
<script>
// P45 instance to use as grid and context.
export let p45 = getContext('p45')
// Origin to use for transforms.
export let origin = p45.centerNode
// Number of sides.
export let sides = 6
// Circle radius.
export let radius = p45.center - 1
// Amount to rotate counter clockwise in degrees, may be negative.
export let rotate = 0
</script>
<!-- Any elements allowable within a `<polygon>`. -->
<slot />
<RegularPolygon
p45={getContext('p45')}
origin={p45.centerNode}
sides={6}
radius={p45.center - 1}
rotate={0}
>
<div />
</RegularPolygon>
<Shape>
Creates a shape from three or more points.
<script>
// P45 instance to use as grid and context.
export let p45 = getContext('p45')
// Either an array off commands or a line separated list of commands.
export let commands = /* Simple Wallace & Gromit rocket drawing */
// ID of a mask cut out.
export let mask = ""
// Either an array off commands or a line separated list of commands.
export let transforms = ""
// Origin to use for transforms.
export let origin = p45.centerNode
</script>
<!-- Any elements allowable within a `<path>`. -->
<slot />
<Shape
p45={getContext('p45')}
commands={/* Simple Wallace & Gromit rocket drawing */}
mask=""
transforms=""
origin={p45.centerNode}
>
<div />
</Shape>
<Transform>
Creates a group for simple transformations.
<script>
// P45 instance to use as grid and context.
export let p45 = getContext('p45')
// Either an array off commands or a line separated list of commands.
export let transforms = ""
// Origin to use for transforms.
export let origin = p45.centerNode
</script>
<!-- Components and elements to transform within a `<g>`. -->
<slot />
<Transform
p45={getContext('p45')}
transforms=""
origin={p45.centerNode}
>
<div />
</Transform>
FAQs
Svelte library for programmatically crafting grid based SVGs.
We found that p45 demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.
Security News
A Stanford study reveals 9.5% of engineers contribute almost nothing, costing tech $90B annually, with remote work fueling the rise of "ghost engineers."
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.