@anand502/ananddropdown 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.babelrc +3 -0
- package/dist/index.js +1 -0
- package/package.json +36 -0
- package/src/AnandDropdown.js +25 -0
- package/src/index.js +3 -0
- package/webpack.config.js +31 -0
package/.babelrc
ADDED
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("react")):"function"==typeof define&&define.amd?define(["react"],t):"object"==typeof exports?exports.anandDropdown=t(require("react")):e.anandDropdown=t(e.react)}(self,e=>(()=>{"use strict";var t={155(t){t.exports=e}},r={};function n(e){var o=r[e];if(void 0!==o)return o.exports;var a=r[e]={exports:{}};return t[e](a,a.exports,n),a.exports}n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t},n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var o={};n.r(o),n.d(o,{default:()=>i});var a=n(155),u=n.n(a);function l(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r<t;r++)n[r]=e[r];return n}const i=function(e){var t,r,n=e.options,o=void 0===n?[]:n,i=e.onChange,c=(t=(0,a.useState)(""),r=2,function(e){if(Array.isArray(e))return e}(t)||function(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,a,u,l=[],i=!0,c=!1;try{if(a=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;i=!1}else for(;!(i=(n=a.call(r)).done)&&(l.push(n.value),l.length!==t);i=!0);}catch(e){c=!0,o=e}finally{try{if(!i&&null!=r.return&&(u=r.return(),Object(u)!==u))return}finally{if(c)throw o}}return l}}(t,r)||function(e,t){if(e){if("string"==typeof e)return l(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?l(e,t):void 0}}(t,r)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()),f=c[0],d=c[1];return u().createElement("select",{value:f,onChange:function(e){d(e.target.value),i&&i(e.target.value)}},u().createElement("option",{value:""},"Select option"),o.map(function(e,t){return u().createElement("option",{key:t,value:e},e)}))};return o})());
|
package/package.json
ADDED
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@anand502/ananddropdown",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "Reusable React dropdown component",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
|
|
7
|
+
"scripts": {
|
|
8
|
+
"build": "webpack",
|
|
9
|
+
"test": "echo \"No test specified\""
|
|
10
|
+
},
|
|
11
|
+
|
|
12
|
+
"keywords": [
|
|
13
|
+
"react",
|
|
14
|
+
"dropdown",
|
|
15
|
+
"react-dropdown",
|
|
16
|
+
"ananddropdown"
|
|
17
|
+
],
|
|
18
|
+
|
|
19
|
+
"author": "Anand Singh",
|
|
20
|
+
|
|
21
|
+
"license": "ISC",
|
|
22
|
+
|
|
23
|
+
"peerDependencies": {
|
|
24
|
+
"react": ">=16",
|
|
25
|
+
"react-dom": ">=16"
|
|
26
|
+
},
|
|
27
|
+
|
|
28
|
+
"devDependencies": {
|
|
29
|
+
"@babel/core": "^7.29.0",
|
|
30
|
+
"@babel/preset-env": "^7.29.0",
|
|
31
|
+
"@babel/preset-react": "^7.28.5",
|
|
32
|
+
"babel-loader": "^10.0.0",
|
|
33
|
+
"webpack": "^5.105.2",
|
|
34
|
+
"webpack-cli": "^6.0.1"
|
|
35
|
+
}
|
|
36
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import React, { useState } from "react";
|
|
2
|
+
|
|
3
|
+
const AnandDropdown = ({ options = [], onChange }) => {
|
|
4
|
+
const [selected, setSelected] = useState("");
|
|
5
|
+
|
|
6
|
+
const handleChange = (e) => {
|
|
7
|
+
setSelected(e.target.value);
|
|
8
|
+
onChange && onChange(e.target.value);
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
return (
|
|
12
|
+
<select value={selected} onChange={handleChange}>
|
|
13
|
+
<option value="">Select option</option>
|
|
14
|
+
|
|
15
|
+
{options.map((item, index) => (
|
|
16
|
+
<option key={index} value={item}>
|
|
17
|
+
{item}
|
|
18
|
+
</option>
|
|
19
|
+
))}
|
|
20
|
+
|
|
21
|
+
</select>
|
|
22
|
+
);
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
export default AnandDropdown;
|
package/src/index.js
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
const path = require("path");
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
mode: "production",
|
|
5
|
+
|
|
6
|
+
entry: "./src/index.js",
|
|
7
|
+
|
|
8
|
+
output: {
|
|
9
|
+
path: path.resolve(__dirname, "dist"),
|
|
10
|
+
filename: "index.js",
|
|
11
|
+
library: "anandDropdown",
|
|
12
|
+
libraryTarget: "umd",
|
|
13
|
+
},
|
|
14
|
+
|
|
15
|
+
module: {
|
|
16
|
+
rules: [
|
|
17
|
+
{
|
|
18
|
+
test: /\.js$/,
|
|
19
|
+
exclude: /node_modules/,
|
|
20
|
+
use: {
|
|
21
|
+
loader: "babel-loader",
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
],
|
|
25
|
+
},
|
|
26
|
+
|
|
27
|
+
externals: {
|
|
28
|
+
react: "react",
|
|
29
|
+
"react-dom": "react-dom",
|
|
30
|
+
},
|
|
31
|
+
};
|