Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
react-flag-icon-css
Advanced tools
A simple React
SVG country flags component: it works with React Css Modules
(default) or standard Css
.
React Flag Icon Css is distributed as an npm package.
We recommend installing and managing npm
packages with yarn
:
$ yarn add react-flag-icon-css
or with npm
:
$ npm install --save react-flag-icon-css
We recommend using the Webpack 2
module bundler and ecosystem to assemble your app, but this module should work with other bundlers.
If you are using Webpack
, you will need to install and configure a few commmonly used modules (see the Webpack 2 example project):
$ yarn add -D babel-loader css-loader file-loader style-loader extract-text-webpack-plugin
or with npm
:
$ npm install --save-dev ...
Import FlagIconFactory
from react-flag-icon-css
, it accepts the React
module as the first argument and creates the FlagIcon
component. This approach ensures that FlagIcon
uses your app's React
instance, avoiding issues such as two versions of React
being loaded at the same time.
import React from 'react'
import ReactDOM from 'react-dom'
import FlagIconFactory from 'react-flag-icon-css'
const FlagIcon = FlagIconFactory(React)
// If you are not using css modules, write the following:
// const FlagIcon = FlagIconFactory(React, { useCssModules: false })
const App = (props = {}) =>
<div>
<FlagIcon code={props.code} size={props.size} />
</div>
const rootEL = document.body.querySelector('#app')
const appProps = { code: 'it', size: '3x' }
ReactDOM.render(<App {...appProps} />, rootEL)
A Webpack 2 example project is available.
The entries marked with *
are required.
Prop | Type | Flow Type | Default | Description | Supported values |
---|---|---|---|---|---|
code * | String | FlagIconCodeType 1 | ISO 3166-1-alpha-2 code. | The list is here. | |
size | String | FlagIconSizeType | lg, 2x, 3x, 4x, 5x | ||
flip | String | FlagIconFlipType | horizontal, vertical | ||
rotate | Number | FlagIconRotateType | 30, 60, 90, 180, 270 | ||
squared | Boolean | boolean | false | Uses the 1x1 image if true . | |
Component | String | string | span | e.g span , div | |
Children | String | React$Element<*> | React element. | e.g <Something /> |
Remember to always build FlagIcon
with FlagIconFactory
.
1 Upgrade to version 1.0.15 or later of this module.
The entries marked with *
are required.
Argument | Type | Flow Type | Description | Supported values |
---|---|---|---|---|
React * | Module | ReactModule | Your app's React instance. | Versions in peerDependencies. |
options | Object | FlagIconOptionsType |
Argument | Type | Flow Type | Description | Supported values | Default |
---|---|---|---|---|---|
useCssModules | Boolean | Boolean | Use react-css-modules . | true , false | true |
customCodes 2 | Object | Object | An object literal whose keys are your custom codes. Example. | ||
themeStyles | Object | CssModule | Set this if useCssModules is true and a) you want toapply styles to FlagIcon using .theme-base and/orb) you are using [custom flags](#Custom flags). |
2 Upgrade to version 1.0.15 or later of this module.
FlagIconFactory options.customCodes
to make this module aware of your codes. Otherwise: runtime warnings in development (and Flow errors, if you use it).React Css Modules
, import your styles in someVariable
and set FlagIconFactory options.themeStyles
to someVariable
. Otherwise: runtime React Css Modules
errors.Flow
use CustomFlagIconFactory
and not FlagIconFactory
. Otherwise: Flow
errors.We recommend organizing your custom flags in a folder similar to example-custom-flags
. You may copy-paste it in the root of your app and replace the codes and images.
Example folder structure:
|-- app.js
|-- example-custom-flags
|--index.js
|--istyles.css
|--images
|--1x1
|--ex1.svg
|--ex2.svg
|--ex3.svg
|--4x3
|--ex1.svg
|--ex2.svg
|--ex3.svg
Write the styles for each one of your codes, and load the appropriate images:
/* example-custom-flags/styles.css */
/**
* Note: you can use PostCSS, SASS or whatever preprocessor your
* app is using here.
*/
.flag-icon-ex1 {
background-image: url(../images/4x3/ex1.svg);
}
.flag-icon-ex1.flag-icon-squared {
background-image: url(../images/1x1/ex1.svg);
}
/* ... */
Import the styles and export them and the object with your codes:
/* example-custom-flags/index.js */
import styles from './styles.css'
const codes = {
ex1: 'Example 1 country',
ex2: 'Example 2 country',
ex3: 'Example 3 country',
}
// You can comment or remove the following line if you don't use Facebook's Flow.
export type CustomCodeType = $Keys<typeof codes>
export { styles, codes }
Import CustomFlagIconFactory
in your app and build FlagIcon
as shown:
/* app.js */
import React from 'react'
import CustomFlagIconFactory from 'react-flag-icon-css'
import { styles, codes } from './my-custom-flags'
// Using 'react-css-modules'? Use this:
const optionsCssModules = { customCodes: codes, themeStyles: styles }
const FlagIconCssModules = CustomFlagIconFactory(React, optionsCssModules)
// Using global CSS? Use this instead:
const options = { useCssModules: false, customCodes: codes }
const FlagIcon = CustomFlagIconFactory(React, options)
Note: when you build FlagIcon with CustomFlagIconFactory, it can be used with both built-in and custom codes.
Runtime type checking: in development mode (process.env.NODE_ENV !== 'production'
), when using unsupported props or prop values, you are warned at runtime by Failed prop type errors in the browser console. Feature powered by prop-types
.
Static type checking: if you use Facebook's flow
in your app (otherwise you can skip this section, unless you want to submit a pull request), it should automatically pick up this package's definitions from the .js.flow
files that are distributed with it, checking your code accordingly when you run yarn flow
. Using the latest Flow
version or the version in ./package.json
is recommended. We also recommend using a Flow
-aware editor such as Nuclide
for Atom
.
Contributions are welcome:
:pencil2: Write code: use a topic branch, follow the AngularJS commit style guidelines and check that yarn prepublish
(build, test, type checking, linting ...) returns zero errors before opening a PR. If you want to make major modifications to the code, please open an issue to discuss them first.
:bug: Report a bug: first, search all issues. If nothing turns up, open a new issue and be as specific as possible, so that we can reproduce your setup and find out if it is a bug or a configuration issue.
:triangular_ruler: Propose a feature: first, search all issues. If nothing turns up, open a new issue and describe what the proposed feature should do, why you think it is important and an example use case.
Thanks! :blue_heart:
:star: Starring it lets you keep track of this project and helps more people discover it.
This project uses the great SVG country flags from flag-icon-css.
This project is licensed under the terms of the MIT license.
FAQs
React SVG country flags component
The npm package react-flag-icon-css receives a total of 5,785 weekly downloads. As such, react-flag-icon-css popularity was classified as popular.
We found that react-flag-icon-css demonstrated a not healthy version release cadence and project activity because the last version was released 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
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.