{"id":15700822,"url":"https://github.com/blakeembrey/style-helper","last_synced_at":"2025-05-12T15:26:28.420Z","repository":{"id":46949047,"uuid":"99849341","full_name":"blakeembrey/style-helper","owner":"blakeembrey","description":"Small helpers for working with CSS-in-JS","archived":false,"fork":false,"pushed_at":"2023-12-12T07:37:26.000Z","size":494,"stargazers_count":6,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-04-23T08:55:18.359Z","etag":null,"topics":["css","css-in-js","free-style","stylesheet","utility"],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/blakeembrey.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2017-08-09T20:19:07.000Z","updated_at":"2021-10-07T06:09:44.000Z","dependencies_parsed_at":"2024-10-09T13:46:28.461Z","dependency_job_id":null,"html_url":"https://github.com/blakeembrey/style-helper","commit_stats":{"total_commits":48,"total_committers":3,"mean_commits":16.0,"dds":0.3125,"last_synced_commit":"80c42bc30c8bd1c9a77311bd0e7e8e10cf644174"},"previous_names":[],"tags_count":9,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blakeembrey%2Fstyle-helper","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blakeembrey%2Fstyle-helper/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blakeembrey%2Fstyle-helper/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/blakeembrey%2Fstyle-helper/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/blakeembrey","download_url":"https://codeload.github.com/blakeembrey/style-helper/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":253764788,"owners_count":21960631,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["css","css-in-js","free-style","stylesheet","utility"],"created_at":"2024-10-03T19:54:37.417Z","updated_at":"2025-05-12T15:26:28.389Z","avatar_url":"https://github.com/blakeembrey.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Style Helper\n\n[![NPM version](https://img.shields.io/npm/v/style-helper.svg?style=flat)](https://npmjs.org/package/style-helper)\n[![NPM downloads](https://img.shields.io/npm/dm/style-helper.svg?style=flat)](https://npmjs.org/package/style-helper)\n[![Build status](https://img.shields.io/travis/blakeembrey/style-helper.svg?style=flat)](https://travis-ci.org/blakeembrey/style-helper)\n[![Test coverage](https://img.shields.io/coveralls/blakeembrey/style-helper.svg?style=flat)](https://coveralls.io/r/blakeembrey/style-helper?branch=master)\n\n\u003e **Style Helper** is a small utility for CSS-in-JS functions.\n\n## Installation\n\n```\nnpm install style-helper --save\n```\n\n## Usage\n\n```js\nimport { quote, url, objectify, merge } from 'style-helper'\n```\n\n### Quote\n\nWrap a string in quotes (useful for the psuedo-element `content` property).\n\n```js\ncss({\n  '\u0026:before': {\n    content: quote('Hello World') //=\u003e `\"Hello World\"`\n  }\n})\n```\n\n### URL\n\nWrap a string in the CSS `url()` function.\n\n```js\ncss({\n  backgroundImage: url('image.png') //=\u003e `url(\"image.png\")`\n})\n```\n\n### Merge\n\nMerge CSS objects recursively.\n\n```js\nimport { ellipsis } from './styles'\n\ncss(merge({ padding: 10 }, ellipsis)) //=\u003e { padding: 10, ... }\n```\n\n### Multi\n\nRepeats the same style for multiple selectors ([reference issue](https://github.com/blakeembrey/free-style/issues/72)).\n\n```js\ncss(multi(['\u0026 .a', '\u0026 .b'], { margin: 10 }))\n```\n\n### Objectify\n\nTurn a list of arguments into an object (`...[key, value]`).\n\n```js\n// Simple properties.\ncss(objectify(\n  ['padding', 10],\n  ['margin', 10]\n)) //=\u003e { padding: 10, margin: 10 }\n\n// Array key for repeating property values.\ncss(objectify(\n  [\n    ['\u0026 .a', '\u0026 .b'],\n    { margin: 10 }\n  ]\n)) //=\u003e { '\u0026 .a': { margin: 10 }, '\u0026 .b': { margin: 10 } }\n```\n\n## License\n\nMIT license\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fblakeembrey%2Fstyle-helper","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fblakeembrey%2Fstyle-helper","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fblakeembrey%2Fstyle-helper/lists"}