diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 9a610913f00c8..ba775febd263b 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -77,6 +77,15 @@ don't see it, feel free to [open a new issue][open an issue]. [open an issue]: https://github.com/badges/shields/issues/new/choose +### Requesting new logos + +We consume logos via [the SimpleIcons project][simple-icons github], and +encourage you to contribute logos there. Please review their +[guidance][simple-icons contributing] before doing so. + +[simple-icons github]: https://github.com/simple-icons/simple-icons +[simple-icons contributing]: https://github.com/simple-icons/simple-icons/blob/develop/CONTRIBUTING.md + ### Spreading the word Feel free to star the repository. This will help increase the visibility of the project, therefore attracting more users and contributors to Shields! @@ -154,10 +163,6 @@ To run the integration tests: There is a [High-level code walkthrough](doc/code-walkthrough.md) describing the layout of the project. -### Logos - -We have [documentation for logo usage](doc/logos.md) which includes [contribution guidance](doc/logos.md#contributing-logos) - ## Pull Requests All code changes are incorporated via pull requests, and pull requests are always squashed into a single commit on merging. Therefore there's no requirement to squash commits within your PR, but feel free to squash or restructure the commits on your PR branch if you think it will be helpful. PRs with well structured commits are always easier to review! diff --git a/README.md b/README.md index f47e925813fae..2c265024a5963 100644 --- a/README.md +++ b/README.md @@ -224,9 +224,6 @@ Alumni: All assets and code are under the [CC0 LICENSE](LICENSE) and in the public domain unless specified otherwise. -The assets in `logo/` are trademarks of their respective companies and are -under their terms and license. - ## Community Thanks to the people and companies who donate money, services or time to keep the project running. [https://shields.io/community](https://shields.io/community) diff --git a/core/base-service/coalesce-badge.js b/core/base-service/coalesce-badge.js index 588d9bd0dcd41..91104d65e1101 100644 --- a/core/base-service/coalesce-badge.js +++ b/core/base-service/coalesce-badge.js @@ -17,12 +17,10 @@ import toArray from './to-array.js' // // Logos are resolved in this manner: // -// 1. When `?logo=` contains a named logo or the name of one of the Shields -// logos or contains base64-encoded SVG, that logo is used. When a -// `&logoColor=` is specified, that color is used (except for the -// base64-encoded logos). Otherwise the default color is used. If the color -// is specified for a multicolor Shield logo, the named logo will be used and -// colored. The appearance of the logo can be customized using `logoWidth`, +// 1. When `?logo=` contains a simple-icons logo or contains a base64-encoded +// SVG, that logo is used. When a `&logoColor=` is specified, that color is +// used (except for the base64-encoded logos). Otherwise the default color +// is used. The appearance of the logo can be customized using `logoWidth`, // When `?logo=` is specified, any logo-related parameters specified // dynamically by the service, or by default in the service, are ignored. // 2. The second precedence is the dynamic logo returned by a service. This is diff --git a/core/base-service/coalesce-badge.spec.js b/core/base-service/coalesce-badge.spec.js index 247c10975fa9e..a98f05debd24f 100644 --- a/core/base-service/coalesce-badge.spec.js +++ b/core/base-service/coalesce-badge.spec.js @@ -1,5 +1,5 @@ import { expect } from 'chai' -import { getShieldsIcon, getSimpleIcon } from '../../lib/logos.js' +import { getSimpleIcon } from '../../lib/logos.js' import coalesceBadge from './coalesce-badge.js' describe('coalesceBadge', function () { @@ -138,7 +138,7 @@ describe('coalesceBadge', function () { }) it('when a social badge, uses the default named logo', function () { - // .not.be.empty for confidence that nothing has changed with `getShieldsIcon()`. + // .not.be.empty for confidence that nothing has changed with `getSimpleIcon()`. expect( coalesceBadge({ style: 'social' }, {}, { namedLogo: 'appveyor' }).logo, ).to.equal(getSimpleIcon({ name: 'appveyor' })).and.not.be.empty @@ -149,52 +149,35 @@ describe('coalesceBadge', function () { namedLogo: 'npm', }) expect(coalesceBadge({}, { namedLogo: 'npm' }, {}).logo).to.equal( - getShieldsIcon({ name: 'npm' }), + getSimpleIcon({ name: 'npm' }), ).and.not.to.be.empty }) - it('applies the named monochrome logo with color', function () { + it('applies the named logo with color', function () { expect( coalesceBadge({}, { namedLogo: 'dependabot', logoColor: 'blue' }, {}) .logo, - ).to.equal(getShieldsIcon({ name: 'dependabot', color: 'blue' })).and.not + ).to.equal(getSimpleIcon({ name: 'dependabot', color: 'blue' })).and.not .to.be.empty }) - it('applies the named multicolored logo with color', function () { - expect( - coalesceBadge({}, { namedLogo: 'npm', logoColor: 'blue' }, {}).logo, - ).to.equal(getSimpleIcon({ name: 'npm', color: 'blue' })).and.not.to.be - .empty - }) - it('overrides the logo', function () { expect( coalesceBadge({ logo: 'npm' }, { namedLogo: 'appveyor' }, {}).logo, - ).to.equal(getShieldsIcon({ name: 'npm' })).and.not.be.empty + ).to.equal(getSimpleIcon({ name: 'npm' })).and.not.be.empty }) - it('overrides the monochrome logo with a color', function () { + it('overrides the logo with a color', function () { expect( coalesceBadge( { logo: 'dependabot', logoColor: 'blue' }, { namedLogo: 'appveyor' }, {}, ).logo, - ).to.equal(getShieldsIcon({ name: 'dependabot', color: 'blue' })).and.not + ).to.equal(getSimpleIcon({ name: 'dependabot', color: 'blue' })).and.not .be.empty }) - it('overrides multicolored logo with a color', function () { - expect( - coalesceBadge( - { logo: 'npm', logoColor: 'blue' }, - { namedLogo: 'appveyor' }, - {}, - ).logo, - ).to.equal(getSimpleIcon({ name: 'npm', color: 'blue' })).and.not.be.empty - }) - it("when the logo is overridden, it ignores the service's logo color and width", function () { expect( coalesceBadge( @@ -206,35 +189,25 @@ describe('coalesceBadge', function () { }, {}, ).logo, - ).to.equal(getShieldsIcon({ name: 'npm' })).and.not.be.empty + ).to.equal(getSimpleIcon({ name: 'npm' })).and.not.be.empty }) - it("overrides the service monochome logo's color", function () { + it("overrides the service logo's color", function () { expect( coalesceBadge( { logoColor: 'blue' }, { namedLogo: 'dependabot', logoColor: 'red' }, {}, ).logo, - ).to.equal(getShieldsIcon({ name: 'dependabot', color: 'blue' })).and.not + ).to.equal(getSimpleIcon({ name: 'dependabot', color: 'blue' })).and.not .be.empty }) - it("overrides the service multicolored logo's color", function () { - expect( - coalesceBadge( - { logoColor: 'blue' }, - { namedLogo: 'npm', logoColor: 'red' }, - {}, - ).logo, - ).to.equal(getSimpleIcon({ name: 'npm', color: 'blue' })).and.not.be.empty - }) - // https://github.com/badges/shields/issues/2998 it('overrides logoSvg', function () { const logoSvg = '' expect(coalesceBadge({ logo: 'npm' }, { logoSvg }, {}).logo).to.equal( - getShieldsIcon({ name: 'npm' }), + getSimpleIcon({ name: 'npm' }), ).and.not.be.empty }) }) diff --git a/core/base-service/openapi.js b/core/base-service/openapi.js index 3d2e6082ee639..bc8d7ffc80303 100644 --- a/core/base-service/openapi.js +++ b/core/base-service/openapi.js @@ -124,7 +124,7 @@ function category2openapi({ category, services, sort = false }) { in: 'query', required: false, description: - 'One of the named logos (bitcoin, dependabot, gitlab, npm, paypal, serverfault, stackexchange, superuser, telegram, travis) or simple-icons. All simple-icons are referenced using icon slugs. You can click the icon title on simple-icons to copy the slug or they can be found in the slugs.md file in the simple-icons repository. Further info.', + 'Icon slug from simple-icons. You can click the icon title on simple-icons to copy the slug or they can be found in the slugs.md file in the simple-icons repository. Further info.', schema: { type: 'string', }, @@ -135,7 +135,7 @@ function category2openapi({ category, services, sort = false }) { in: 'query', required: false, description: - 'The color of the logo (hex, rgb, rgba, hsl, hsla and css named colors supported). Supported for named logos and Shields logos but not for custom logos. For multicolor Shields logos, the corresponding named logo will be used and colored.', + 'The color of the logo (hex, rgb, rgba, hsl, hsla and css named colors supported). Supported for simple-icons logos but not for custom logos.', schema: { type: 'string', }, @@ -146,7 +146,7 @@ function category2openapi({ category, services, sort = false }) { in: 'query', required: false, description: - 'Make icons adaptively resize by setting `auto`. Useful for some wider logos like `amd` and `amg`. Supported for simple-icons logos only.', + 'Make icons adaptively resize by setting `auto`. Useful for some wider logos like `amd` and `amg`. Supported for simple-icons logos but not for custom logos.', schema: { type: 'string', }, diff --git a/core/base-service/openapi.spec.js b/core/base-service/openapi.spec.js index e8911653784e7..aa56fb7a6196d 100644 --- a/core/base-service/openapi.spec.js +++ b/core/base-service/openapi.spec.js @@ -80,7 +80,7 @@ const expected = { in: 'query', required: false, description: - 'One of the named logos (bitcoin, dependabot, gitlab, npm, paypal, serverfault, stackexchange, superuser, telegram, travis) or simple-icons. All simple-icons are referenced using icon slugs. You can click the icon title on simple-icons to copy the slug or they can be found in the slugs.md file in the simple-icons repository. Further info.', + 'Icon slug from simple-icons. You can click the icon title on simple-icons to copy the slug or they can be found in the slugs.md file in the simple-icons repository. Further info.', schema: { type: 'string' }, example: 'appveyor', }, @@ -89,7 +89,7 @@ const expected = { in: 'query', required: false, description: - 'The color of the logo (hex, rgb, rgba, hsl, hsla and css named colors supported). Supported for named logos and Shields logos but not for custom logos. For multicolor Shields logos, the corresponding named logo will be used and colored.', + 'The color of the logo (hex, rgb, rgba, hsl, hsla and css named colors supported). Supported for simple-icons logos but not for custom logos.', schema: { type: 'string' }, example: 'violet', }, @@ -98,7 +98,7 @@ const expected = { in: 'query', required: false, description: - 'Make icons adaptively resize by setting `auto`. Useful for some wider logos like `amd` and `amg`. Supported for simple-icons logos only.', + 'Make icons adaptively resize by setting `auto`. Useful for some wider logos like `amd` and `amg`. Supported for simple-icons logos but not for custom logos.', schema: { type: 'string', }, diff --git a/dangerfile.js b/dangerfile.js index 527be50d9c10b..f4199dff9369e 100644 --- a/dangerfile.js +++ b/dangerfile.js @@ -22,7 +22,6 @@ const server = fileMatch('core/server/**.js', '!*.spec.js') const serverTests = fileMatch('core/server/**.spec.js') const legacyHelpers = fileMatch('lib/**/*.js', '!*.spec.js') const legacyHelperTests = fileMatch('lib/**/*.spec.js') -const logos = fileMatch('logo/*.svg') const packageJson = fileMatch('package.json') const packageLock = fileMatch('package-lock.json') const secretsDocs = fileMatch('doc/server-secrets.md') @@ -78,17 +77,6 @@ if (legacyHelpers.created) { ) } -if (logos.created) { - message( - [ - ':art: Thanks for submitting a logo.
', - 'Please ensure your contribution follows our ', - '[guidance](https://github.com/badges/shields/blob/master/doc/logos.md#contributing-logos) ', - 'for logo submissions.', - ].join(''), - ) -} - if (capitals.created || underscores.created) { fail( [ diff --git a/doc/logos.md b/doc/logos.md deleted file mode 100644 index 84915cb18fb01..0000000000000 --- a/doc/logos.md +++ /dev/null @@ -1,42 +0,0 @@ -# Logos - -For documentation on using logos, see https://shields.io/docs/logos - -## Contributing Logos - -Our preferred way to consume icons is via the SimpleIcons logo. As a first port of call, we encourage you to contribute logos to [the SimpleIcons project][simple-icons github]. Please review their [guidance](https://github.com/simple-icons/simple-icons/blob/develop/CONTRIBUTING.md) before contributing. - -In some cases we may also accept logo submissions directly. In general, we do this only when: - -- We have a corresponding badge on the homepage, (e.g. the Eclipse logo because we support service badges for the Eclipse Marketplace). We may also approve logos for other tools widely used by developers. -- The logo provided in SimpleIcons is unclear when displayed at small size on a badge. -- There is substantial benefit in using a multi-colored icon over a monochrome icon. -- The logo doesn't meet the requirements to be included in the SimpleIcons set. - -If you are submitting a pull request for a custom logo, please: - -- Minimize SVG files through [SVGO][]. This can be done in one of two ways - - The [SVGO Command Line Tool][svgo] - - Install SVGO - - With npm: `npm install -g svgo` - - With Homebrew: `brew install svgo` - - Run the following command `svgo --precision=3 icon.svg -o icon.min.svg` - - Check if there is a loss of quality in the output, if so increase the precision. - - The [SVGOMG Online Tool][svgomg] - - Click "Open SVG" and select an SVG file. - - Set the precision to about 3, depending on if there is a loss of quality. - - Leave the remaining settings untouched (or reset them with the button at the bottom of the settings). - - Click the download button. -- Set a viewbox and ensure the logo is scaled to fit the viewbox, while preserving the logo's original proportions. This means the icon should be touching at least two sides of the viewbox. -- Ensure the logo is vertically and horizontally centered. -- Ensure the logo is minified to a single line with no formatting. -- Ensure the SVG does not contain extraneous attributes. -- Ensure your submission conforms to any relevant brand or logo guidelines. - -### Problems - -We try to ensure our logos are compliant with brand guidelines. If one of our custom logos does not conform to the necessary brand guidelines, please open an issue on the [shields.io tracker](https://github.com/badges/shields/issues) and we'll work with you to resolve it. If a logo from the simple-icons set does not conform to the relevant brand guidelines, please open an issue on the [simple-icons tracker](https://github.com/simple-icons/simple-icons/issues) first. - -[simple-icons github]: https://github.com/simple-icons/simple-icons -[svgo]: https://github.com/svg/svgo -[svgomg]: https://jakearchibald.github.io/svgomg/ diff --git a/frontend/blog/2024-07-10-sunsetting-shields-custom-logos.md b/frontend/blog/2024-07-10-sunsetting-shields-custom-logos.md new file mode 100644 index 0000000000000..de9a2f6074041 --- /dev/null +++ b/frontend/blog/2024-07-10-sunsetting-shields-custom-logos.md @@ -0,0 +1,39 @@ +--- +slug: sunsetting-shields-custom-logos +title: Sunsetting Shields custom logos +authors: + name: PyvesB + title: Shields.io Core Team + url: https://github.com/PyvesB + image_url: https://avatars.githubusercontent.com/u/10694593 +tags: [] +--- + +Following discussions in [#9476](https://github.com/badges/shields/issues/9476), we've gone ahead and deleted all custom logos that were maintained on the Shields.io side (bitcoin, dependabot, gitlab, npm, paypal, serverfault, stackexchange, superuser, telegram, travis), and will solely rely on the [Simple-Icons project](https://github.com/simple-icons/simple-icons) to provide named logos for our badges from now on. If you were using a Shields custom logo, you will have transparently switched over to the corresponding Simple-Icon and do not need to make changes to your badges. + +The reasons behind this decision include the following: + +- reducing code complexity and induced overhead by deleting several dozens lines of code. +- reducing maintenance load; we received regular pull requests to add logos that do not comply with our guidelines, or various other related questions. +- providing a less confusing user experience; all named logos now behave in the same way with regards to `logoColor` and other parameters. +- reducing frustration for contributors who prepared logo pull requests only to be told that they hadn't read the guidelines or that there was a misalignment on the interpretation of said guidelines. +- reinforcing Shields.io's mission to provide consistent badges, with all named logos now being monochrome. +- improving compliance with third-party brands; Simple-Icons regularly reviews whether their icons respect latest brand guidelines, whereas we do not. +- unblocking [#4947](https://github.com/badges/shields/issues/4947). + +We do acknowledge the fact that some of you voiced your preference for a given Shields custom logo over its Simple-Icons equivalent in [#7684](https://github.com/badges/shields/issues/7684). If you really want to go back to the Shields custom logo, you can leverage [custom logos](https://shields.io/docs/logos#custom-logos) to do so. Here are the corresponding Base64-encoded logo parameters for all our existing logos: + +| Name | Logo Preview | `logo` Parameter | +| ------------- | :------------------------------------------------------------------------------------------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| bitcoin | ![bitcoin](https://github.com/badges/shields/assets/10694593/20ea99c4-a557-476c-91a8-3b886ce98e5e) | `` | +| dependabot | ![dependabot](https://github.com/badges/shields/assets/10694593/5fb27ba4-f940-4782-bba0-8c01f98cce0e) | `` | +| gitlab | ![gitlab](https://github.com/badges/shields/assets/10694593/e9c8e584-3860-4fe2-b802-2ed7c87f996f) | `` | +| npm | ![npm](https://github.com/badges/shields/assets/10694593/ba629fa3-a467-4c96-b191-62c339faac66) | `` | +| paypal | ![paypal](https://github.com/badges/shields/assets/10694593/f2eacc65-7a19-4816-8897-f7723a97b26f) | `` | +| serverfault | ![serverfault](https://github.com/badges/shields/assets/10694593/d1b7a0e5-2465-4009-ba5f-89f364554a46) | `` | +| stackexchange | ![stackexchange](https://github.com/badges/shields/assets/10694593/409644d3-4679-4f0d-9fb9-538215eec8c7) | `` | +| superuser | ![superuser](https://github.com/badges/shields/assets/10694593/f8d0b5ad-5b67-49f8-8989-59256baad56e) | `` | +| telegram | ![telegram](https://github.com/badges/shields/assets/10694593/c5c5acc3-f434-4a8d-a834-6d94a7ffb45a) | `` | +| travis | ![travis](https://github.com/badges/shields/assets/10694593/67110d9b-b825-4ef7-85ff-1bba963121e1) | `` | + +Feel free to reach out to us if you have any questions, and happy badging! diff --git a/frontend/docs/logos.md b/frontend/docs/logos.md index 0b43ef16091c5..244f309c9b148 100644 --- a/frontend/docs/logos.md +++ b/frontend/docs/logos.md @@ -12,12 +12,6 @@ We support a wide range of logos via [SimpleIcons](https://simpleicons.org/). Al You can click the icon title on simple-icons to copy the slug or they can be found in the slugs.md file in the simple-icons repository. NB - the Simple Icons site and slugs.md page may at times contain new icons that haven't yet been pulled into Shields.io yet. More information on how and when we incorporate icon updates can be found [here](https://github.com/badges/shields/discussions/5369). -## Shields logos - -We also maintain a small number of custom logos for a handful of services: https://github.com/badges/shields/tree/master/logo They can also be referenced by name and take preference to SimpleIcons e.g: - -![](https://img.shields.io/npm/v/npm.svg?logo=npm) - https://img.shields.io/npm/v/npm.svg?logo=npm - ## Custom Logos Any custom logo can be passed in a URL parameter by base64 encoding it. e.g: @@ -26,12 +20,7 @@ Any custom logo can be passed in a URL parameter by base64 encoding it. e.g: ## logoColor parameter -The `logoColor` param can be used to set the color of the logo. Hex, rgb, rgba, hsl, hsla and css named colors can all be used. For SimpleIcons named logos (which are monochrome), the color will be applied to the SimpleIcons logo. +The `logoColor` param can be used to set the color of the SimpleIcons named logo. Hex, rgb, rgba, hsl, hsla and css named colors can all be used. - ![](https://img.shields.io/badge/logo-javascript-blue?logo=javascript) - https://img.shields.io/badge/logo-javascript-blue?logo=javascript - ![](https://img.shields.io/badge/logo-javascript-blue?logo=javascript&logoColor=f5f5f5) - https://img.shields.io/badge/logo-javascript-blue?logo=javascript&logoColor=f5f5f5 - -In the case where Shields hosts a custom multi-colored logo, if the `logoColor` param is passed, the corresponding SimpleIcons logo will be substituted and colored. - -- ![](https://img.shields.io/badge/logo-gitlab-blue?logo=gitlab) - https://img.shields.io/badge/logo-gitlab-blue?logo=gitlab -- ![](https://img.shields.io/badge/logo-gitlab-blue?logo=gitlab&logoColor=white) - https://img.shields.io/badge/logo-gitlab-blue?logo=gitlab&logoColor=white diff --git a/lib/load-logos.js b/lib/load-logos.js deleted file mode 100644 index 9af0cc875b32f..0000000000000 --- a/lib/load-logos.js +++ /dev/null @@ -1,36 +0,0 @@ -import fs from 'fs' -import path from 'path' -import { fileURLToPath } from 'url' -import { svg2base64 } from './svg-helpers.js' - -function loadLogos() { - // Cache svg logos from disk in base64 string - const logos = {} - const logoDir = path.join( - path.dirname(fileURLToPath(import.meta.url)), - '..', - 'logo', - ) - const logoFiles = fs.readdirSync(logoDir) - logoFiles.forEach(filename => { - if (filename[0] === '.') { - return - } - // filename is eg, github.svg - const svg = fs.readFileSync(`${logoDir}/${filename}`).toString() - const base64 = svg2base64(svg) - // logo is monochrome if it only has one fill= statement - const isMonochrome = (svg.match(/fill="(.+?)"/g) || []).length === 1 - - // eg, github - const name = filename.slice(0, -'.svg'.length).toLowerCase() - logos[name] = { - isMonochrome, - svg, - base64, - } - }) - return logos -} - -export default loadLogos diff --git a/lib/logos.js b/lib/logos.js index 5927aa59947de..813b4cf3675ff 100644 --- a/lib/logos.js +++ b/lib/logos.js @@ -6,9 +6,7 @@ import { } from '../badge-maker/lib/color.js' import coalesce from '../core/base-service/coalesce.js' import { svg2base64, getIconSize, resetIconPosition } from './svg-helpers.js' -import loadLogos from './load-logos.js' import loadSimpleIcons from './load-simple-icons.js' -const logos = loadLogos() const simpleIcons = loadSimpleIcons() // for backwards-compatibility with deleted logos @@ -19,6 +17,7 @@ const logoAliases = { scrutinizer: 'scrutinizer-ci', stackoverflow: 'stack-overflow', tfs: 'azure-devops', + travis: 'travisci', } const lightThreshold = 0.4 const darkThreshold = 0.6 @@ -59,24 +58,6 @@ function decodeDataUrlFromQueryParam(value) { return isDataUrl(maybeDataUrl) ? maybeDataUrl : undefined } -function getShieldsIcon({ name, color }) { - if (!(name in logos)) { - return undefined - } - - const { svg, base64, isMonochrome } = logos[name] - const svgColor = toSvgColor(color) - if (svgColor) { - if (isMonochrome) { - return svg2base64(svg.replace(/fill="(.+?)"/g, `fill="${svgColor}"`)) - } else { - return undefined - } - } else { - return base64 - } -} - function getSimpleIconStyle({ icon, style }) { const { hex } = icon if (style !== 'social' && brightness(normalizeColor(hex)) <= lightThreshold) { @@ -93,7 +74,7 @@ function getSimpleIconStyle({ icon, style }) { // badge. If `size` is not 'auto', the icon will be displayed at its original. // https://github.com/badges/shields/pull/9191 function getSimpleIcon({ name, color, style, size }) { - const key = name === 'travis' ? 'travis-ci' : name.replace(/ /g, '-') + const key = name.replace(/ /g, '-') if (!(key in simpleIcons)) { return undefined @@ -134,10 +115,7 @@ function prepareNamedLogo({ name, color, style, size }) { name = logoAliases[name] } - return ( - getShieldsIcon({ name, color }) || - getSimpleIcon({ name, color, style, size }) - ) + return getSimpleIcon({ name, color, style, size }) } function makeLogo(defaultNamedLogo, overrides) { @@ -159,7 +137,6 @@ export { isDataUrl, decodeDataUrlFromQueryParam, prepareNamedLogo, - getShieldsIcon, getSimpleIcon, makeLogo, } diff --git a/lib/logos.spec.js b/lib/logos.spec.js index be67e3d2f6af0..cdefebc9171ba 100644 --- a/lib/logos.spec.js +++ b/lib/logos.spec.js @@ -31,24 +31,6 @@ describe('Logo helpers', function () { }) test(prepareNamedLogo, () => { - // use multicolored shield icon - given({ name: 'npm' }).expect( - '', - ) - // use simple icon with color - given({ name: 'npm', color: 'blue' }).expect( - '', - ) - - // use monochrome shield icon - given({ name: 'dependabot' }).expect( - '', - ) - // use monochrome shield icon with color - given({ name: 'dependabot', color: 'blue' }).expect( - '', - ) - // use simple icon given({ name: 'github' }).expect( '', @@ -66,15 +48,6 @@ describe('Logo helpers', function () { '', ) - // use travis shield icon - given({ name: 'travis' }).expect( - '', - ) - // use travis simple icon with color - given({ name: 'travis', color: 'green' }).expect( - '', - ) - it('preserves color if light logo on dark background', function () { const logo = prepareNamedLogo({ name: 'javascript' }) const decodedLogo = Buffer.from( @@ -145,7 +118,7 @@ describe('Logo helpers', function () { undefined, ) given('npm', {}).expect( - '', + '', ) }) }) diff --git a/logo/bitcoin.svg b/logo/bitcoin.svg deleted file mode 100644 index dcd28493f3493..0000000000000 --- a/logo/bitcoin.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/logo/dependabot.svg b/logo/dependabot.svg deleted file mode 100644 index 0244208c7a3d5..0000000000000 --- a/logo/dependabot.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/logo/gitlab.svg b/logo/gitlab.svg deleted file mode 100644 index 1d123609f6c1a..0000000000000 --- a/logo/gitlab.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/logo/npm.svg b/logo/npm.svg deleted file mode 100644 index d8270435936c2..0000000000000 --- a/logo/npm.svg +++ /dev/null @@ -1 +0,0 @@ - diff --git a/logo/paypal.svg b/logo/paypal.svg deleted file mode 100644 index 1e1e4df7f819e..0000000000000 --- a/logo/paypal.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/logo/serverfault.svg b/logo/serverfault.svg deleted file mode 100644 index 3519238dfc885..0000000000000 --- a/logo/serverfault.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/logo/stackexchange.svg b/logo/stackexchange.svg deleted file mode 100644 index a5f409d70650e..0000000000000 --- a/logo/stackexchange.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/logo/superuser.svg b/logo/superuser.svg deleted file mode 100644 index 443f7682d6a31..0000000000000 --- a/logo/superuser.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/logo/telegram.svg b/logo/telegram.svg deleted file mode 100644 index 7765a143fa0ac..0000000000000 --- a/logo/telegram.svg +++ /dev/null @@ -1 +0,0 @@ - diff --git a/logo/travis.svg b/logo/travis.svg deleted file mode 100644 index bd858287c4768..0000000000000 --- a/logo/travis.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/services/endpoint/endpoint.service.js b/services/endpoint/endpoint.service.js index 1a4b68e7ac793..bffd6fa8fe3f4 100644 --- a/services/endpoint/endpoint.service.js +++ b/services/endpoint/endpoint.service.js @@ -77,8 +77,8 @@ The endpoint badge takes a single required query param: url, which namedLogo - Default: none. One of the named logos supported by Shields - or simple-icons. Can be + Default: none. One of the + simple-icons slugs. Can be overridden by the query string. @@ -90,9 +90,7 @@ The endpoint badge takes a single required query param: url, which logoColor Default: none. Same meaning as the query string. Can be overridden by - the query string. Only works for named logos and Shields logos. If you - override the color of a multicolor Shield logo, the corresponding - named logo will be used and colored. + the query string. Only works for simple-icons logos. diff --git a/services/endpoint/endpoint.tester.js b/services/endpoint/endpoint.tester.js index 858ca792d97ab..c6f5186bdec4d 100644 --- a/services/endpoint/endpoint.tester.js +++ b/services/endpoint/endpoint.tester.js @@ -1,6 +1,6 @@ import zlib from 'zlib' import { expect } from 'chai' -import { getShieldsIcon, getSimpleIcon } from '../../lib/logos.js' +import { getSimpleIcon } from '../../lib/logos.js' import { createServiceTester } from '../tester.js' export const t = await createServiceTester() @@ -63,7 +63,7 @@ t.create('named logo') ) .after((err, res, body) => { expect(err).not.to.be.ok - expect(body).to.include(getShieldsIcon({ name: 'npm' })) + expect(body).to.include(getSimpleIcon({ name: 'npm' })) }) t.create('named logo with color') @@ -83,7 +83,7 @@ t.create('named logo with color') }) const logoSvg = Buffer.from( - getShieldsIcon({ name: 'npm' }).replace('data:image/svg+xml;base64,', ''), + getSimpleIcon({ name: 'npm' }).replace('data:image/svg+xml;base64,', ''), 'base64', ).toString('ascii') @@ -99,7 +99,7 @@ t.create('custom svg logo') ) .after((err, res, body) => { expect(err).not.to.be.ok - expect(body).to.include(getShieldsIcon({ name: 'npm' })) + expect(body).to.include(getSimpleIcon({ name: 'npm' })) }) t.create('logoWidth')