react-quizifyy-component 1.0.1
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/README.md +157 -0
- package/dist/index.cjs.js +22 -0
- package/dist/index.css +1 -0
- package/dist/index.es.js +490 -0
- package/dist/quiz-logo.png +0 -0
- package/package.json +50 -0
package/README.md
ADDED
@@ -0,0 +1,157 @@
|
|
1
|
+
# ๐ React Quiz App
|
2
|
+
|
3
|
+
A dynamic and interactive quiz application built with React. Features real-time answer selection, smooth timer animation, result tracking, and a detailed summary page. Ideal for assessments, learning platforms, or trivia games.
|
4
|
+
|
5
|
+
 <!-- Replace with an actual screenshot if available -->
|
6
|
+
|
7
|
+
---
|
8
|
+
|
9
|
+
## โจ Features
|
10
|
+
|
11
|
+
- ๐ Interactive multiple-choice questions
|
12
|
+
- โฑ๏ธ Live countdown timer with smooth animation
|
13
|
+
- โ
Real-time answer tracking and validation
|
14
|
+
- ๐ Detailed summary of correct and incorrect answers
|
15
|
+
- โ๏ธ Built using React functional components and hooks
|
16
|
+
- ๐ Clean codebase with reusable components
|
17
|
+
|
18
|
+
---
|
19
|
+
|
20
|
+
## ๐ฆ Installation
|
21
|
+
|
22
|
+
Install via npm:
|
23
|
+
|
24
|
+
```bash
|
25
|
+
npm install react-quizify-component
|
26
|
+
```
|
27
|
+
|
28
|
+
---
|
29
|
+
|
30
|
+
## โ๏ธ Basic Usage
|
31
|
+
|
32
|
+
```jsx
|
33
|
+
import React from 'react';
|
34
|
+
import QuizApp from 'react-quiz-app';
|
35
|
+
|
36
|
+
function App() {
|
37
|
+
return <Quiz />;
|
38
|
+
}
|
39
|
+
```
|
40
|
+
|
41
|
+
---
|
42
|
+
|
43
|
+
## ๐ฏ Component API
|
44
|
+
|
45
|
+
### `<Question />`
|
46
|
+
|
47
|
+
Displays a single question with options.
|
48
|
+
|
49
|
+
**Props:**
|
50
|
+
|
51
|
+
| Prop | Type | Description |
|
52
|
+
|-------------------|----------|------------------------------------------|
|
53
|
+
| `question` | `object` | Question text and answer options |
|
54
|
+
| `index` | `number` | Current question index |
|
55
|
+
| `onSelectAnswer` | `func` | Callback when answer is selected |
|
56
|
+
|
57
|
+
---
|
58
|
+
|
59
|
+
## ๐ Summary Page
|
60
|
+
|
61
|
+
At the end of the quiz, the summary includes:
|
62
|
+
|
63
|
+
- โ
Number of correct answers
|
64
|
+
- โ Number of wrong answers
|
65
|
+
- ๐งพ List of all questions, selected answers, and correct answers
|
66
|
+
|
67
|
+
Useful for review and performance insight.
|
68
|
+
|
69
|
+
---
|
70
|
+
|
71
|
+
## ๐จ Theme Customization
|
72
|
+
|
73
|
+
You can apply custom colors and styles via your own stylesheet or using Tailwind/CSS variables. Example:
|
74
|
+
|
75
|
+
```css
|
76
|
+
:root {
|
77
|
+
--primary-color: #00FFF7;
|
78
|
+
--background-color: #0D0D0D;
|
79
|
+
--text-color: #FFFFFF;
|
80
|
+
}
|
81
|
+
```
|
82
|
+
|
83
|
+
Or simply add class-based styles (e.g., `className="dark neon-theme"`).
|
84
|
+
|
85
|
+
---
|
86
|
+
|
87
|
+
## ๐ Using Custom Questions
|
88
|
+
|
89
|
+
To add your own quiz content, create a `questions.js` file in your project and export an array of question objects like this:
|
90
|
+
|
91
|
+
```js
|
92
|
+
// questions.js
|
93
|
+
export default [
|
94
|
+
{
|
95
|
+
id: 'q1',
|
96
|
+
text: 'Which of the following definitions best describes React.js?',
|
97
|
+
answers: [
|
98
|
+
'A library to build user interfaces with help of declarative code.',
|
99
|
+
'A library for managing state in web applications.',
|
100
|
+
'A framework to build user interfaces with help of imperative code.',
|
101
|
+
'A library used for building mobile applications only.',
|
102
|
+
],
|
103
|
+
},
|
104
|
+
{
|
105
|
+
id: 'q2',
|
106
|
+
text: 'What purpose do React hooks serve?',
|
107
|
+
answers: [
|
108
|
+
'Enabling the use of state and other React features in functional components.',
|
109
|
+
'Creating responsive layouts in React applications.',
|
110
|
+
'Handling errors within the application.',
|
111
|
+
'Part of the Redux library for managing global state.',
|
112
|
+
],
|
113
|
+
},
|
114
|
+
{
|
115
|
+
id: 'q3',
|
116
|
+
text: 'Can you identify what JSX is?',
|
117
|
+
answers: [
|
118
|
+
'A JavaScript extension that adds HTML-like syntax to JavaScript.',
|
119
|
+
'A JavaScript library for building dynamic user interfaces.',
|
120
|
+
'A specific HTML version that was explicitly created for React.',
|
121
|
+
'A tool for making HTTP requests in a React application.',
|
122
|
+
],
|
123
|
+
},
|
124
|
+
];
|
125
|
+
```
|
126
|
+
|
127
|
+
### ๐ Note:
|
128
|
+
- The **first answer** in the `answers` array is considered the **correct answer**.
|
129
|
+
- Each question must have a unique `id`.
|
130
|
+
|
131
|
+
### โ
Import and Use in App:
|
132
|
+
|
133
|
+
```js
|
134
|
+
import questions from './questions';
|
135
|
+
|
136
|
+
function App() {
|
137
|
+
return <Quiz questions={questions} />;
|
138
|
+
}
|
139
|
+
```
|
140
|
+
|
141
|
+
---
|
142
|
+
|
143
|
+
## ๐ Development Log
|
144
|
+
|
145
|
+
- โ
Designed and implemented summary page with result breakdown
|
146
|
+
- โ
Displayed correct and incorrect answer counts
|
147
|
+
- โ
Returned a detailed list of user answers
|
148
|
+
- โ
Refactored props structure for cleaner component interface
|
149
|
+
- โ
Improved progress bar transition for smoother experience
|
150
|
+
|
151
|
+
---
|
152
|
+
|
153
|
+
## ๐ License
|
154
|
+
|
155
|
+
This project is licensed under the MIT License.
|
156
|
+
|
157
|
+
---
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const w=require("react");var Q={exports:{}},C={};/**
|
2
|
+
* @license React
|
3
|
+
* react-jsx-runtime.production.js
|
4
|
+
*
|
5
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
6
|
+
*
|
7
|
+
* This source code is licensed under the MIT license found in the
|
8
|
+
* LICENSE file in the root directory of this source tree.
|
9
|
+
*/var L;function nA(){if(L)return C;L=1;var n=Symbol.for("react.transitional.element"),c=Symbol.for("react.fragment");function R(s,i,o){var t=null;if(o!==void 0&&(t=""+o),i.key!==void 0&&(t=""+i.key),"key"in i){o={};for(var a in i)a!=="key"&&(o[a]=i[a])}else o=i;return i=o.ref,{$$typeof:n,type:s,key:t,ref:i!==void 0?i:null,props:o}}return C.Fragment=c,C.jsx=R,C.jsxs=R,C}var D={};/**
|
10
|
+
* @license React
|
11
|
+
* react-jsx-runtime.development.js
|
12
|
+
*
|
13
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
14
|
+
*
|
15
|
+
* This source code is licensed under the MIT license found in the
|
16
|
+
* LICENSE file in the root directory of this source tree.
|
17
|
+
*/var k;function tA(){return k||(k=1,process.env.NODE_ENV!=="production"&&function(){function n(A){if(A==null)return null;if(typeof A=="function")return A.$$typeof===AA?null:A.displayName||A.name||null;if(typeof A=="string")return A;switch(A){case b:return"Fragment";case G:return"Profiler";case S:return"StrictMode";case Z:return"Suspense";case J:return"SuspenseList";case $:return"Activity"}if(typeof A=="object")switch(typeof A.tag=="number"&&console.error("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),A.$$typeof){case X:return"Portal";case p:return(A.displayName||"Context")+".Provider";case T:return(A._context.displayName||"Context")+".Consumer";case W:var e=A.render;return A=A.displayName,A||(A=e.displayName||e.name||"",A=A!==""?"ForwardRef("+A+")":"ForwardRef"),A;case _:return e=A.displayName||null,e!==null?e:n(A.type)||"Memo";case z:e=A._payload,A=A._init;try{return n(A(e))}catch{}}return null}function c(A){return""+A}function R(A){try{c(A);var e=!1}catch{e=!0}if(e){e=console;var E=e.error,u=typeof Symbol=="function"&&Symbol.toStringTag&&A[Symbol.toStringTag]||A.constructor.name||"Object";return E.call(e,"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",u),c(A)}}function s(A){if(A===b)return"<>";if(typeof A=="object"&&A!==null&&A.$$typeof===z)return"<...>";try{var e=n(A);return e?"<"+e+">":"<...>"}catch{return"<...>"}}function i(){var A=h.A;return A===null?null:A.getOwner()}function o(){return Error("react-stack-top-frame")}function t(A){if(y.call(A,"key")){var e=Object.getOwnPropertyDescriptor(A,"key").get;if(e&&e.isReactWarning)return!1}return A.key!==void 0}function a(A,e){function E(){N||(N=!0,console.error("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",e))}E.isReactWarning=!0,Object.defineProperty(A,"key",{get:E,configurable:!0})}function l(){var A=n(this.type);return F[A]||(F[A]=!0,console.error("Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release.")),A=this.props.ref,A!==void 0?A:null}function B(A,e,E,u,f,g,H,O){return E=g.ref,A={$$typeof:j,type:A,key:e,props:g,_owner:f},(E!==void 0?E:null)!==null?Object.defineProperty(A,"ref",{enumerable:!1,get:l}):Object.defineProperty(A,"ref",{enumerable:!1,value:null}),A._store={},Object.defineProperty(A._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:0}),Object.defineProperty(A,"_debugInfo",{configurable:!1,enumerable:!1,writable:!0,value:null}),Object.defineProperty(A,"_debugStack",{configurable:!1,enumerable:!1,writable:!0,value:H}),Object.defineProperty(A,"_debugTask",{configurable:!1,enumerable:!1,writable:!0,value:O}),Object.freeze&&(Object.freeze(A.props),Object.freeze(A)),A}function I(A,e,E,u,f,g,H,O){var d=e.children;if(d!==void 0)if(u)if(eA(d)){for(u=0;u<d.length;u++)M(d[u]);Object.freeze&&Object.freeze(d)}else console.error("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else M(d);if(y.call(e,"key")){d=n(A);var v=Object.keys(e).filter(function(rA){return rA!=="key"});u=0<v.length?"{key: someKey, "+v.join(": ..., ")+": ...}":"{key: someKey}",V[d+u]||(v=0<v.length?"{"+v.join(": ..., ")+": ...}":"{}",console.error(`A props object containing a "key" prop is being spread into JSX:
|
18
|
+
let props = %s;
|
19
|
+
<%s {...props} />
|
20
|
+
React keys must be passed directly to JSX without using spread:
|
21
|
+
let props = %s;
|
22
|
+
<%s key={someKey} {...props} />`,u,d,v,d),V[d+u]=!0)}if(d=null,E!==void 0&&(R(E),d=""+E),t(e)&&(R(e.key),d=""+e.key),"key"in e){E={};for(var x in e)x!=="key"&&(E[x]=e[x])}else E=e;return d&&a(E,typeof A=="function"?A.displayName||A.name||"Unknown":A),B(A,d,g,f,i(),E,H,O)}function M(A){typeof A=="object"&&A!==null&&A.$$typeof===j&&A._store&&(A._store.validated=1)}var P=w,j=Symbol.for("react.transitional.element"),X=Symbol.for("react.portal"),b=Symbol.for("react.fragment"),S=Symbol.for("react.strict_mode"),G=Symbol.for("react.profiler"),T=Symbol.for("react.consumer"),p=Symbol.for("react.context"),W=Symbol.for("react.forward_ref"),Z=Symbol.for("react.suspense"),J=Symbol.for("react.suspense_list"),_=Symbol.for("react.memo"),z=Symbol.for("react.lazy"),$=Symbol.for("react.activity"),AA=Symbol.for("react.client.reference"),h=P.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,y=Object.prototype.hasOwnProperty,eA=Array.isArray,m=console.createTask?console.createTask:function(){return null};P={"react-stack-bottom-frame":function(A){return A()}};var N,F={},U=P["react-stack-bottom-frame"].bind(P,o)(),Y=m(s(o)),V={};D.Fragment=b,D.jsx=function(A,e,E,u,f){var g=1e4>h.recentlyCreatedOwnerStacks++;return I(A,e,E,!1,u,f,g?Error("react-stack-top-frame"):U,g?m(s(A)):Y)},D.jsxs=function(A,e,E,u,f){var g=1e4>h.recentlyCreatedOwnerStacks++;return I(A,e,E,!0,u,f,g?Error("react-stack-top-frame"):U,g?m(s(A)):Y)}}()),D}var q;function EA(){return q||(q=1,process.env.NODE_ENV==="production"?Q.exports=nA():Q.exports=tA()),Q.exports}var r=EA();function iA({answers:n,onSelect:c}){const R=w.useRef();return R.current||(R.current=[...n],R.current.sort(()=>Math.random()-.5)),r.jsx("ul",{id:"answers",children:R.current.map(s=>r.jsx("li",{className:"answer",children:r.jsx("button",{onClick:()=>c(s),children:s})},s))})}function sA({timeout:n,onTimeout:c,mode:R}){const[s,i]=w.useState(n),o=w.useRef(null),t=w.useRef(null);return w.useEffect(()=>{o.current=performance.now();const a=l=>{const B=l-o.current,I=Math.max(n-B,0);i(I),B<n?t.current=requestAnimationFrame(a):c()};return t.current=requestAnimationFrame(a),()=>{cancelAnimationFrame(t.current)}},[n,c]),r.jsx("progress",{id:"question-progress",max:n,value:s,className:R})}function aA({index:n,onSelectAnswer:c,onSkipAnswer:R,questions:s}){const[i,o]=w.useState({selectedAnswer:""});let t=1e4;i.selectedAnswer&&(t=1e3);function a(l){c(l)}return r.jsxs("div",{id:"question",children:[r.jsx(sA,{timeout:t,onTimeout:i.selectedAnswer===""?R:null},t),r.jsx("h2",{children:s[n].text}),r.jsx(iA,{answers:s[n].answers,selectedAnswer:i.selectedAnswer,onSelect:a})]})}const RA="",K=[{id:"q1",text:"Which of the following definitions best describes React.js?",answers:["A library to build user interfaces with help of declarative code.","A library for managing state in web applications.","A framework to build user interfaces with help of imperative code.","A library used for building mobile applications only."]},{id:"q2",text:"What purpose do React hooks serve?",answers:["Enabling the use of state and other React features in functional components.","Creating responsive layouts in React applications.","Handling errors within the application.","Part of the Redux library for managing global state."]},{id:"q3",text:"Can you identify what JSX is?",answers:["A JavaScript extension that adds HTML-like syntax to JavaScript.","A JavaScript library for building dynamic user interfaces.","A specific HTML version that was explicitly created for React.","A tool for making HTTP requests in a React application."]},{id:"q4",text:"What is the most common way to create a component in React?",answers:["By defining a JavaScript function that returns a renderable value.","By defining a custom HTML tag in JavaScript.","By creating a file with a .jsx extension.",'By using the "new" keyword followed by the component name.']},{id:"q5",text:'What does the term "React state" imply?',answers:["An object in a component that holds values and may cause the component to render on change.","The lifecycle phase a React component is in.","The overall status of a React application, including all props and components.","A library for managing global state in React applications."]},{id:"q6",text:"How do you typically render list content in React apps?",answers:["By using the map() method to iterate over an array of data and returning JSX.","By using the for() loop to iterate over an array of data and returning JSX.","By using the forEach() method to iterate over an array of data and returning JSX.","By using the loop() method to iterate over an array of data and returning JSX."]},{id:"q7",text:"Which approach can NOT be used to render content conditionally?",answers:["Using a the #if template syntax.","Using a ternary operator.","Using the && operator.","Using an if-else statement."]}];function oA({userAnswers:n}){const c=n.filter(t=>t===null),R=n.filter((t,a)=>t===K[a].answers[0]),s=Math.round(c.length/n.length*100),i=Math.round(R.length/n.length*100),o=100-s-i;return r.jsxs("div",{id:"summary",children:[r.jsx("img",{src:RA,alt:"Quiz Completed"}),r.jsx("h2",{children:"Quiz Completed"}),r.jsxs("div",{id:"summary-stats",children:[r.jsxs("p",{children:[r.jsxs("span",{className:"number",children:[s,"%"]}),r.jsx("span",{className:"text",children:"skipped"})]}),r.jsxs("p",{children:[r.jsxs("span",{className:"number",children:[i,"%"]}),r.jsx("span",{className:"text",children:"answered correctly"})]}),r.jsxs("p",{children:[r.jsxs("span",{className:"number",children:[o,"%"]}),r.jsx("span",{className:"text",children:"answered incorrectly"})]})]}),r.jsx("ol",{children:n.map((t,a)=>{let l="user-answer";return t===null?l+=" skipped":t===K[a].answers[0]?l+=" correct":l+=" wrong",r.jsxs("li",{children:[r.jsx("h3",{children:a+1}),r.jsx("p",{className:"question",children:K[a].text}),r.jsx("p",{className:l,children:t??"Skipped"})]},a)})})]})}const cA="";function uA(n){return r.jsxs("header",{children:[r.jsx("img",{src:cA,alt:"logo"}),r.jsx("h1",{children:"Quizify"})]})}function dA({questions:n}){const[c,R]=w.useState([]),s=c.length,i=n,o=s===n.length,t=w.useCallback(function(B){R(I=>[...I,B])},[]),a=w.useCallback(()=>t(null),[t]);return o?r.jsx(oA,{userAnswers:c}):r.jsxs(r.Fragment,{children:[r.jsx(uA,{}),r.jsx("main",{children:r.jsx("div",{id:"quiz",children:r.jsx(aA,{index:s,onSelectAnswer:t,onSkipAnswer:a,questions:i},s)})})]})}exports.Quiz=dA;
|
package/dist/index.css
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
@import"https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@400;700&family=Roboto:wght@400;700&display=swap";*{box-sizing:border-box}html{font-family:Roboto,sans-serif;line-height:1.5;color:#ebe7ef;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;height:100%}body{margin:0;padding:2rem;background-color:#0f1e40;background-attachment:fixed;background-size:cover;background-position:center}header{margin:2rem 0;text-align:center}header img{width:3rem;height:3rem;filter:drop-shadow(0 0 4px rgba(0,0,0,.6))}header h1{font-family:Roboto Condensed,sans-serif;font-weight:700;font-size:2.5rem;letter-spacing:.6rem;margin:0;text-transform:uppercase;background:linear-gradient(90deg,#fff 40%,#61bae4 60%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}#last-try{max-width:40rem;margin:2rem auto;font-size:.8rem;font-family:Roboto Condensed,sans-serif;text-align:center}#last-try h2{margin:0;font-size:1rem;color:#9c7fd3;text-transform:uppercase}#last-try ul{list-style:none;margin:0;padding:0;display:flex;gap:1rem;font-size:1.25rem;color:#a690c5}#quiz{max-width:50rem;margin:auto;padding:2rem;background:linear-gradient(180deg,#0f1e40,#0f1e40);border-radius:8px;box-shadow:1px 1px 8px 4px #0c052099;text-align:center}#question-overview{font-family:Roboto Condensed,sans-serif;font-size:.8rem;color:#9082a3;margin:0;text-transform:uppercase}#question progress{width:50%;height:.5rem;border-radius:24px;background:#61bae4;margin:0}#question progress::-webkit-progress-bar{background:#7c7785;border-radius:24px}#question progress::-webkit-progress-value{background:#61bae4;border-radius:24px}#question progress.answered{background:#f8e59c}#question progress.answered::-webkit-progress-value{background:#f8e59c}#question progress.answered::-webkit-progress-bar{background:#6a558a}#question h2{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:400;margin:.5rem 0 2.5rem;color:#fff}#answers{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;align-items:center;gap:.5rem}.answer{width:90%;margin:0 auto}.answer button{display:inline-block;width:100%;font-family:Roboto Condensed,sans-serif;font-size:.9rem;padding:1rem 2rem;border:none;border-radius:24px;background:#61bae4;cursor:pointer;transition:all .2s ease-in-out}.answer button:hover,.answer button:focus{background:#fff;color:#61bae4}.answer button.selected{background:#f5a76c;color:#2c203d}.answer button.correct{background:#5af59d;color:#2c203d}.answer button.wrong{background:#f55a98;color:#2c203d}#skip-action{margin-top:2rem}#skip-action button{font-family:Roboto Condensed,sans-serif;font-size:1rem;border:none;background:transparent;color:#9082a3;cursor:pointer}#skip-action button:hover,#skip-action button:focus{color:#c7bfd6}#summary{max-width:40rem;margin:2rem auto;padding:2rem;background:linear-gradient(180deg,#0f1e40,#0f1e40);color:#fff;border-radius:8px;box-shadow:1px 1px 8px 1px #0009;animation:slide-in-from-bottom .7s ease-out}#summary img{display:block;width:8rem;height:8rem;object-fit:contain;margin:0 auto 1rem;padding:1rem;filter:drop-shadow(0 0 4px rgba(0,0,0,.6));border:2px solid #3a2353;border-radius:50%;background:#fff}#summary h2{font-family:Roboto,sans-serif;font-size:3rem;text-align:center;margin:0;text-transform:uppercase;color:#61bae4}#summary ol{list-style:none;margin:2rem auto;padding:0;text-align:center}#summary li{margin:2rem 0}#summary h3{font-family:Roboto Condensed,sans-serif;font-size:1rem;margin:0 auto;display:flex;justify-content:center;align-items:center;background:#61bae4;color:#0f1e40;width:2rem;height:2rem;border-radius:50%}#summary .question{margin:.25rem 0;font-size:1rem;color:#fff}#summary .user-answer{margin:.25rem 0;font-family:Roboto Condensed,sans-serif;font-weight:700;color:#fff}#summary .user-answer.correct{color:#af0}#summary .user-answer.wrong{color:red}#summary .user-answer.skipped{color:#61bae4;font-weight:400}#summary-stats{display:flex;gap:3rem;width:60%;margin:2rem auto;padding-bottom:2rem;border-bottom:2px solid #61BAE4}#summary-stats p{flex:1;display:flex;flex-direction:column;margin:0}#summary-stats .number{font-family:Roboto Condensed,sans-serif;font-size:3rem;color:#61bae4}#summary-stats .text{font-family:Roboto Condensed,sans-serif;text-transform:uppercase;font-size:.8rem;color:#61bae4;margin-top:-.7rem;margin-left:.2rem;letter-spacing:.1rem}@keyframes slide-in-from-bottom{0%{opacity:0;transform:translateY(10%)}to{opacity:1;transform:translateY(0)}}#question-progress{transition:value .1s linear}
|
package/dist/index.es.js
ADDED
@@ -0,0 +1,490 @@
|
|
1
|
+
import EA, { useRef as K, useState as M, useEffect as iA, useCallback as k } from "react";
|
2
|
+
var P = { exports: {} }, v = {};
|
3
|
+
/**
|
4
|
+
* @license React
|
5
|
+
* react-jsx-runtime.production.js
|
6
|
+
*
|
7
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
8
|
+
*
|
9
|
+
* This source code is licensed under the MIT license found in the
|
10
|
+
* LICENSE file in the root directory of this source tree.
|
11
|
+
*/
|
12
|
+
var X;
|
13
|
+
function sA() {
|
14
|
+
if (X) return v;
|
15
|
+
X = 1;
|
16
|
+
var n = Symbol.for("react.transitional.element"), c = Symbol.for("react.fragment");
|
17
|
+
function a(s, i, o) {
|
18
|
+
var t = null;
|
19
|
+
if (o !== void 0 && (t = "" + o), i.key !== void 0 && (t = "" + i.key), "key" in i) {
|
20
|
+
o = {};
|
21
|
+
for (var R in i)
|
22
|
+
R !== "key" && (o[R] = i[R]);
|
23
|
+
} else o = i;
|
24
|
+
return i = o.ref, {
|
25
|
+
$$typeof: n,
|
26
|
+
type: s,
|
27
|
+
key: t,
|
28
|
+
ref: i !== void 0 ? i : null,
|
29
|
+
props: o
|
30
|
+
};
|
31
|
+
}
|
32
|
+
return v.Fragment = c, v.jsx = a, v.jsxs = a, v;
|
33
|
+
}
|
34
|
+
var C = {};
|
35
|
+
/**
|
36
|
+
* @license React
|
37
|
+
* react-jsx-runtime.development.js
|
38
|
+
*
|
39
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
40
|
+
*
|
41
|
+
* This source code is licensed under the MIT license found in the
|
42
|
+
* LICENSE file in the root directory of this source tree.
|
43
|
+
*/
|
44
|
+
var q;
|
45
|
+
function RA() {
|
46
|
+
return q || (q = 1, process.env.NODE_ENV !== "production" && function() {
|
47
|
+
function n(A) {
|
48
|
+
if (A == null) return null;
|
49
|
+
if (typeof A == "function")
|
50
|
+
return A.$$typeof === rA ? null : A.displayName || A.name || null;
|
51
|
+
if (typeof A == "string") return A;
|
52
|
+
switch (A) {
|
53
|
+
case Q:
|
54
|
+
return "Fragment";
|
55
|
+
case p:
|
56
|
+
return "Profiler";
|
57
|
+
case T:
|
58
|
+
return "StrictMode";
|
59
|
+
case _:
|
60
|
+
return "Suspense";
|
61
|
+
case $:
|
62
|
+
return "SuspenseList";
|
63
|
+
case eA:
|
64
|
+
return "Activity";
|
65
|
+
}
|
66
|
+
if (typeof A == "object")
|
67
|
+
switch (typeof A.tag == "number" && console.error(
|
68
|
+
"Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."
|
69
|
+
), A.$$typeof) {
|
70
|
+
case G:
|
71
|
+
return "Portal";
|
72
|
+
case Z:
|
73
|
+
return (A.displayName || "Context") + ".Provider";
|
74
|
+
case W:
|
75
|
+
return (A._context.displayName || "Context") + ".Consumer";
|
76
|
+
case J:
|
77
|
+
var e = A.render;
|
78
|
+
return A = A.displayName, A || (A = e.displayName || e.name || "", A = A !== "" ? "ForwardRef(" + A + ")" : "ForwardRef"), A;
|
79
|
+
case AA:
|
80
|
+
return e = A.displayName || null, e !== null ? e : n(A.type) || "Memo";
|
81
|
+
case y:
|
82
|
+
e = A._payload, A = A._init;
|
83
|
+
try {
|
84
|
+
return n(A(e));
|
85
|
+
} catch {
|
86
|
+
}
|
87
|
+
}
|
88
|
+
return null;
|
89
|
+
}
|
90
|
+
function c(A) {
|
91
|
+
return "" + A;
|
92
|
+
}
|
93
|
+
function a(A) {
|
94
|
+
try {
|
95
|
+
c(A);
|
96
|
+
var e = !1;
|
97
|
+
} catch {
|
98
|
+
e = !0;
|
99
|
+
}
|
100
|
+
if (e) {
|
101
|
+
e = console;
|
102
|
+
var E = e.error, u = typeof Symbol == "function" && Symbol.toStringTag && A[Symbol.toStringTag] || A.constructor.name || "Object";
|
103
|
+
return E.call(
|
104
|
+
e,
|
105
|
+
"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",
|
106
|
+
u
|
107
|
+
), c(A);
|
108
|
+
}
|
109
|
+
}
|
110
|
+
function s(A) {
|
111
|
+
if (A === Q) return "<>";
|
112
|
+
if (typeof A == "object" && A !== null && A.$$typeof === y)
|
113
|
+
return "<...>";
|
114
|
+
try {
|
115
|
+
var e = n(A);
|
116
|
+
return e ? "<" + e + ">" : "<...>";
|
117
|
+
} catch {
|
118
|
+
return "<...>";
|
119
|
+
}
|
120
|
+
}
|
121
|
+
function i() {
|
122
|
+
var A = b.A;
|
123
|
+
return A === null ? null : A.getOwner();
|
124
|
+
}
|
125
|
+
function o() {
|
126
|
+
return Error("react-stack-top-frame");
|
127
|
+
}
|
128
|
+
function t(A) {
|
129
|
+
if (N.call(A, "key")) {
|
130
|
+
var e = Object.getOwnPropertyDescriptor(A, "key").get;
|
131
|
+
if (e && e.isReactWarning) return !1;
|
132
|
+
}
|
133
|
+
return A.key !== void 0;
|
134
|
+
}
|
135
|
+
function R(A, e) {
|
136
|
+
function E() {
|
137
|
+
F || (F = !0, console.error(
|
138
|
+
"%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",
|
139
|
+
e
|
140
|
+
));
|
141
|
+
}
|
142
|
+
E.isReactWarning = !0, Object.defineProperty(A, "key", {
|
143
|
+
get: E,
|
144
|
+
configurable: !0
|
145
|
+
});
|
146
|
+
}
|
147
|
+
function l() {
|
148
|
+
var A = n(this.type);
|
149
|
+
return U[A] || (U[A] = !0, console.error(
|
150
|
+
"Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release."
|
151
|
+
)), A = this.props.ref, A !== void 0 ? A : null;
|
152
|
+
}
|
153
|
+
function f(A, e, E, u, w, g, m, H) {
|
154
|
+
return E = g.ref, A = {
|
155
|
+
$$typeof: z,
|
156
|
+
type: A,
|
157
|
+
key: e,
|
158
|
+
props: g,
|
159
|
+
_owner: w
|
160
|
+
}, (E !== void 0 ? E : null) !== null ? Object.defineProperty(A, "ref", {
|
161
|
+
enumerable: !1,
|
162
|
+
get: l
|
163
|
+
}) : Object.defineProperty(A, "ref", { enumerable: !1, value: null }), A._store = {}, Object.defineProperty(A._store, "validated", {
|
164
|
+
configurable: !1,
|
165
|
+
enumerable: !1,
|
166
|
+
writable: !0,
|
167
|
+
value: 0
|
168
|
+
}), Object.defineProperty(A, "_debugInfo", {
|
169
|
+
configurable: !1,
|
170
|
+
enumerable: !1,
|
171
|
+
writable: !0,
|
172
|
+
value: null
|
173
|
+
}), Object.defineProperty(A, "_debugStack", {
|
174
|
+
configurable: !1,
|
175
|
+
enumerable: !1,
|
176
|
+
writable: !0,
|
177
|
+
value: m
|
178
|
+
}), Object.defineProperty(A, "_debugTask", {
|
179
|
+
configurable: !1,
|
180
|
+
enumerable: !1,
|
181
|
+
writable: !0,
|
182
|
+
value: H
|
183
|
+
}), Object.freeze && (Object.freeze(A.props), Object.freeze(A)), A;
|
184
|
+
}
|
185
|
+
function B(A, e, E, u, w, g, m, H) {
|
186
|
+
var d = e.children;
|
187
|
+
if (d !== void 0)
|
188
|
+
if (u)
|
189
|
+
if (nA(d)) {
|
190
|
+
for (u = 0; u < d.length; u++)
|
191
|
+
j(d[u]);
|
192
|
+
Object.freeze && Object.freeze(d);
|
193
|
+
} else
|
194
|
+
console.error(
|
195
|
+
"React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead."
|
196
|
+
);
|
197
|
+
else j(d);
|
198
|
+
if (N.call(e, "key")) {
|
199
|
+
d = n(A);
|
200
|
+
var I = Object.keys(e).filter(function(tA) {
|
201
|
+
return tA !== "key";
|
202
|
+
});
|
203
|
+
u = 0 < I.length ? "{key: someKey, " + I.join(": ..., ") + ": ...}" : "{key: someKey}", L[d + u] || (I = 0 < I.length ? "{" + I.join(": ..., ") + ": ...}" : "{}", console.error(
|
204
|
+
`A props object containing a "key" prop is being spread into JSX:
|
205
|
+
let props = %s;
|
206
|
+
<%s {...props} />
|
207
|
+
React keys must be passed directly to JSX without using spread:
|
208
|
+
let props = %s;
|
209
|
+
<%s key={someKey} {...props} />`,
|
210
|
+
u,
|
211
|
+
d,
|
212
|
+
I,
|
213
|
+
d
|
214
|
+
), L[d + u] = !0);
|
215
|
+
}
|
216
|
+
if (d = null, E !== void 0 && (a(E), d = "" + E), t(e) && (a(e.key), d = "" + e.key), "key" in e) {
|
217
|
+
E = {};
|
218
|
+
for (var O in e)
|
219
|
+
O !== "key" && (E[O] = e[O]);
|
220
|
+
} else E = e;
|
221
|
+
return d && R(
|
222
|
+
E,
|
223
|
+
typeof A == "function" ? A.displayName || A.name || "Unknown" : A
|
224
|
+
), f(
|
225
|
+
A,
|
226
|
+
d,
|
227
|
+
g,
|
228
|
+
w,
|
229
|
+
i(),
|
230
|
+
E,
|
231
|
+
m,
|
232
|
+
H
|
233
|
+
);
|
234
|
+
}
|
235
|
+
function j(A) {
|
236
|
+
typeof A == "object" && A !== null && A.$$typeof === z && A._store && (A._store.validated = 1);
|
237
|
+
}
|
238
|
+
var D = EA, z = Symbol.for("react.transitional.element"), G = Symbol.for("react.portal"), Q = Symbol.for("react.fragment"), T = Symbol.for("react.strict_mode"), p = Symbol.for("react.profiler"), W = Symbol.for("react.consumer"), Z = Symbol.for("react.context"), J = Symbol.for("react.forward_ref"), _ = Symbol.for("react.suspense"), $ = Symbol.for("react.suspense_list"), AA = Symbol.for("react.memo"), y = Symbol.for("react.lazy"), eA = Symbol.for("react.activity"), rA = Symbol.for("react.client.reference"), b = D.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, N = Object.prototype.hasOwnProperty, nA = Array.isArray, h = console.createTask ? console.createTask : function() {
|
239
|
+
return null;
|
240
|
+
};
|
241
|
+
D = {
|
242
|
+
"react-stack-bottom-frame": function(A) {
|
243
|
+
return A();
|
244
|
+
}
|
245
|
+
};
|
246
|
+
var F, U = {}, Y = D["react-stack-bottom-frame"].bind(
|
247
|
+
D,
|
248
|
+
o
|
249
|
+
)(), V = h(s(o)), L = {};
|
250
|
+
C.Fragment = Q, C.jsx = function(A, e, E, u, w) {
|
251
|
+
var g = 1e4 > b.recentlyCreatedOwnerStacks++;
|
252
|
+
return B(
|
253
|
+
A,
|
254
|
+
e,
|
255
|
+
E,
|
256
|
+
!1,
|
257
|
+
u,
|
258
|
+
w,
|
259
|
+
g ? Error("react-stack-top-frame") : Y,
|
260
|
+
g ? h(s(A)) : V
|
261
|
+
);
|
262
|
+
}, C.jsxs = function(A, e, E, u, w) {
|
263
|
+
var g = 1e4 > b.recentlyCreatedOwnerStacks++;
|
264
|
+
return B(
|
265
|
+
A,
|
266
|
+
e,
|
267
|
+
E,
|
268
|
+
!0,
|
269
|
+
u,
|
270
|
+
w,
|
271
|
+
g ? Error("react-stack-top-frame") : Y,
|
272
|
+
g ? h(s(A)) : V
|
273
|
+
);
|
274
|
+
};
|
275
|
+
}()), C;
|
276
|
+
}
|
277
|
+
var S;
|
278
|
+
function aA() {
|
279
|
+
return S || (S = 1, process.env.NODE_ENV === "production" ? P.exports = sA() : P.exports = RA()), P.exports;
|
280
|
+
}
|
281
|
+
var r = aA();
|
282
|
+
function oA({ answers: n, onSelect: c }) {
|
283
|
+
const a = K();
|
284
|
+
return a.current || (a.current = [...n], a.current.sort(() => Math.random() - 0.5)), /* @__PURE__ */ r.jsx("ul", { id: "answers", children: a.current.map((s) => /* @__PURE__ */ r.jsx("li", { className: "answer", children: /* @__PURE__ */ r.jsx("button", { onClick: () => c(s), children: s }) }, s)) });
|
285
|
+
}
|
286
|
+
function cA({ timeout: n, onTimeout: c, mode: a }) {
|
287
|
+
const [s, i] = M(n), o = K(null), t = K(null);
|
288
|
+
return iA(() => {
|
289
|
+
o.current = performance.now();
|
290
|
+
const R = (l) => {
|
291
|
+
const f = l - o.current, B = Math.max(n - f, 0);
|
292
|
+
i(B), f < n ? t.current = requestAnimationFrame(R) : c();
|
293
|
+
};
|
294
|
+
return t.current = requestAnimationFrame(R), () => {
|
295
|
+
cancelAnimationFrame(t.current);
|
296
|
+
};
|
297
|
+
}, [n, c]), /* @__PURE__ */ r.jsx(
|
298
|
+
"progress",
|
299
|
+
{
|
300
|
+
id: "question-progress",
|
301
|
+
max: n,
|
302
|
+
value: s,
|
303
|
+
className: a
|
304
|
+
}
|
305
|
+
);
|
306
|
+
}
|
307
|
+
function uA({
|
308
|
+
index: n,
|
309
|
+
onSelectAnswer: c,
|
310
|
+
onSkipAnswer: a,
|
311
|
+
questions: s
|
312
|
+
}) {
|
313
|
+
const [i, o] = M({
|
314
|
+
selectedAnswer: ""
|
315
|
+
});
|
316
|
+
let t = 1e4;
|
317
|
+
i.selectedAnswer && (t = 1e3);
|
318
|
+
function R(l) {
|
319
|
+
c(l);
|
320
|
+
}
|
321
|
+
return /* @__PURE__ */ r.jsxs("div", { id: "question", children: [
|
322
|
+
/* @__PURE__ */ r.jsx(
|
323
|
+
cA,
|
324
|
+
{
|
325
|
+
timeout: t,
|
326
|
+
onTimeout: i.selectedAnswer === "" ? a : null
|
327
|
+
},
|
328
|
+
t
|
329
|
+
),
|
330
|
+
/* @__PURE__ */ r.jsx("h2", { children: s[n].text }),
|
331
|
+
/* @__PURE__ */ r.jsx(
|
332
|
+
oA,
|
333
|
+
{
|
334
|
+
answers: s[n].answers,
|
335
|
+
selectedAnswer: i.selectedAnswer,
|
336
|
+
onSelect: R
|
337
|
+
}
|
338
|
+
)
|
339
|
+
] });
|
340
|
+
}
|
341
|
+
const dA = "", x = [
|
342
|
+
{
|
343
|
+
id: "q1",
|
344
|
+
text: "Which of the following definitions best describes React.js?",
|
345
|
+
answers: [
|
346
|
+
"A library to build user interfaces with help of declarative code.",
|
347
|
+
"A library for managing state in web applications.",
|
348
|
+
"A framework to build user interfaces with help of imperative code.",
|
349
|
+
"A library used for building mobile applications only."
|
350
|
+
]
|
351
|
+
},
|
352
|
+
{
|
353
|
+
id: "q2",
|
354
|
+
text: "What purpose do React hooks serve?",
|
355
|
+
answers: [
|
356
|
+
"Enabling the use of state and other React features in functional components.",
|
357
|
+
"Creating responsive layouts in React applications.",
|
358
|
+
"Handling errors within the application.",
|
359
|
+
"Part of the Redux library for managing global state."
|
360
|
+
]
|
361
|
+
},
|
362
|
+
{
|
363
|
+
id: "q3",
|
364
|
+
text: "Can you identify what JSX is?",
|
365
|
+
answers: [
|
366
|
+
"A JavaScript extension that adds HTML-like syntax to JavaScript.",
|
367
|
+
"A JavaScript library for building dynamic user interfaces.",
|
368
|
+
"A specific HTML version that was explicitly created for React.",
|
369
|
+
"A tool for making HTTP requests in a React application."
|
370
|
+
]
|
371
|
+
},
|
372
|
+
{
|
373
|
+
id: "q4",
|
374
|
+
text: "What is the most common way to create a component in React?",
|
375
|
+
answers: [
|
376
|
+
"By defining a JavaScript function that returns a renderable value.",
|
377
|
+
"By defining a custom HTML tag in JavaScript.",
|
378
|
+
"By creating a file with a .jsx extension.",
|
379
|
+
'By using the "new" keyword followed by the component name.'
|
380
|
+
]
|
381
|
+
},
|
382
|
+
{
|
383
|
+
id: "q5",
|
384
|
+
text: 'What does the term "React state" imply?',
|
385
|
+
answers: [
|
386
|
+
"An object in a component that holds values and may cause the component to render on change.",
|
387
|
+
"The lifecycle phase a React component is in.",
|
388
|
+
"The overall status of a React application, including all props and components.",
|
389
|
+
"A library for managing global state in React applications."
|
390
|
+
]
|
391
|
+
},
|
392
|
+
{
|
393
|
+
id: "q6",
|
394
|
+
text: "How do you typically render list content in React apps?",
|
395
|
+
answers: [
|
396
|
+
"By using the map() method to iterate over an array of data and returning JSX.",
|
397
|
+
"By using the for() loop to iterate over an array of data and returning JSX.",
|
398
|
+
"By using the forEach() method to iterate over an array of data and returning JSX.",
|
399
|
+
"By using the loop() method to iterate over an array of data and returning JSX."
|
400
|
+
]
|
401
|
+
},
|
402
|
+
{
|
403
|
+
id: "q7",
|
404
|
+
text: "Which approach can NOT be used to render content conditionally?",
|
405
|
+
answers: [
|
406
|
+
"Using a the #if template syntax.",
|
407
|
+
"Using a ternary operator.",
|
408
|
+
"Using the && operator.",
|
409
|
+
"Using an if-else statement."
|
410
|
+
]
|
411
|
+
}
|
412
|
+
];
|
413
|
+
function lA({ userAnswers: n }) {
|
414
|
+
const c = n.filter((t) => t === null), a = n.filter(
|
415
|
+
(t, R) => t === x[R].answers[0]
|
416
|
+
), s = Math.round(
|
417
|
+
c.length / n.length * 100
|
418
|
+
), i = Math.round(
|
419
|
+
a.length / n.length * 100
|
420
|
+
), o = 100 - s - i;
|
421
|
+
return /* @__PURE__ */ r.jsxs("div", { id: "summary", children: [
|
422
|
+
/* @__PURE__ */ r.jsx("img", { src: dA, alt: "Quiz Completed" }),
|
423
|
+
/* @__PURE__ */ r.jsx("h2", { children: "Quiz Completed" }),
|
424
|
+
/* @__PURE__ */ r.jsxs("div", { id: "summary-stats", children: [
|
425
|
+
/* @__PURE__ */ r.jsxs("p", { children: [
|
426
|
+
/* @__PURE__ */ r.jsxs("span", { className: "number", children: [
|
427
|
+
s,
|
428
|
+
"%"
|
429
|
+
] }),
|
430
|
+
/* @__PURE__ */ r.jsx("span", { className: "text", children: "skipped" })
|
431
|
+
] }),
|
432
|
+
/* @__PURE__ */ r.jsxs("p", { children: [
|
433
|
+
/* @__PURE__ */ r.jsxs("span", { className: "number", children: [
|
434
|
+
i,
|
435
|
+
"%"
|
436
|
+
] }),
|
437
|
+
/* @__PURE__ */ r.jsx("span", { className: "text", children: "answered correctly" })
|
438
|
+
] }),
|
439
|
+
/* @__PURE__ */ r.jsxs("p", { children: [
|
440
|
+
/* @__PURE__ */ r.jsxs("span", { className: "number", children: [
|
441
|
+
o,
|
442
|
+
"%"
|
443
|
+
] }),
|
444
|
+
/* @__PURE__ */ r.jsx("span", { className: "text", children: "answered incorrectly" })
|
445
|
+
] })
|
446
|
+
] }),
|
447
|
+
/* @__PURE__ */ r.jsx("ol", { children: n.map((t, R) => {
|
448
|
+
let l = "user-answer";
|
449
|
+
return t === null ? l += " skipped" : t === x[R].answers[0] ? l += " correct" : l += " wrong", /* @__PURE__ */ r.jsxs("li", { children: [
|
450
|
+
/* @__PURE__ */ r.jsx("h3", { children: R + 1 }),
|
451
|
+
/* @__PURE__ */ r.jsx("p", { className: "question", children: x[R].text }),
|
452
|
+
/* @__PURE__ */ r.jsx("p", { className: l, children: t ?? "Skipped" })
|
453
|
+
] }, R);
|
454
|
+
}) })
|
455
|
+
] });
|
456
|
+
}
|
457
|
+
const gA = "";
|
458
|
+
function wA(n) {
|
459
|
+
return /* @__PURE__ */ r.jsxs("header", { children: [
|
460
|
+
/* @__PURE__ */ r.jsx("img", { src: gA, alt: "logo" }),
|
461
|
+
/* @__PURE__ */ r.jsx("h1", { children: "Quizify" })
|
462
|
+
] });
|
463
|
+
}
|
464
|
+
function BA({ questions: n }) {
|
465
|
+
const [c, a] = M([]), s = c.length, i = n, o = s === n.length, t = k(
|
466
|
+
function(f) {
|
467
|
+
a((B) => [...B, f]);
|
468
|
+
},
|
469
|
+
[]
|
470
|
+
), R = k(
|
471
|
+
() => t(null),
|
472
|
+
[t]
|
473
|
+
);
|
474
|
+
return o ? /* @__PURE__ */ r.jsx(lA, { userAnswers: c }) : /* @__PURE__ */ r.jsxs(r.Fragment, { children: [
|
475
|
+
/* @__PURE__ */ r.jsx(wA, {}),
|
476
|
+
/* @__PURE__ */ r.jsx("main", { children: /* @__PURE__ */ r.jsx("div", { id: "quiz", children: /* @__PURE__ */ r.jsx(
|
477
|
+
uA,
|
478
|
+
{
|
479
|
+
index: s,
|
480
|
+
onSelectAnswer: t,
|
481
|
+
onSkipAnswer: R,
|
482
|
+
questions: i
|
483
|
+
},
|
484
|
+
s
|
485
|
+
) }) })
|
486
|
+
] });
|
487
|
+
}
|
488
|
+
export {
|
489
|
+
BA as Quiz
|
490
|
+
};
|
Binary file
|
package/package.json
ADDED
@@ -0,0 +1,50 @@
|
|
1
|
+
{
|
2
|
+
"name": "react-quizifyy-component",
|
3
|
+
"version": "1.0.1",
|
4
|
+
"description": "A reusable Quiz component for React",
|
5
|
+
"type": "module",
|
6
|
+
"private": false,
|
7
|
+
"main": "dist/index.cjs.js",
|
8
|
+
"module": "dist/index.es.js",
|
9
|
+
"exports": {
|
10
|
+
".": {
|
11
|
+
"import": "./dist/index.es.js",
|
12
|
+
"require": "./dist/index.js"
|
13
|
+
},
|
14
|
+
"./style.css": "./dist/index.css"
|
15
|
+
},
|
16
|
+
"files": [
|
17
|
+
"dist"
|
18
|
+
],
|
19
|
+
"keywords": ["react", "quiz", "component", "library"],
|
20
|
+
"author": "Your Name",
|
21
|
+
"license": "MIT",
|
22
|
+
"peerDependencies": {
|
23
|
+
"react": "^18.0.0 || ^19.0.0",
|
24
|
+
"react-dom": "^18.0.0 || ^19.0.0"
|
25
|
+
},
|
26
|
+
"scripts": {
|
27
|
+
"dev": "vite",
|
28
|
+
"build": "vite build",
|
29
|
+
"lint": "eslint . --ext js,jsx --report-unused-disable-directives --max-warnings 0",
|
30
|
+
"preview": "vite preview"
|
31
|
+
},
|
32
|
+
"dependencies": {
|
33
|
+
"react": "^19.0.0",
|
34
|
+
"react-dom": "^19.0.0"
|
35
|
+
},
|
36
|
+
"devDependencies": {
|
37
|
+
"@babel/cli": "^7.27.2",
|
38
|
+
"@babel/core": "^7.27.1",
|
39
|
+
"@babel/preset-env": "^7.27.2",
|
40
|
+
"@babel/preset-react": "^7.27.1",
|
41
|
+
"@types/react": "^18.2.15",
|
42
|
+
"@types/react-dom": "^18.2.7",
|
43
|
+
"@vitejs/plugin-react": "^4.0.3",
|
44
|
+
"eslint": "^8.45.0",
|
45
|
+
"eslint-plugin-react": "^7.32.2",
|
46
|
+
"eslint-plugin-react-hooks": "^4.6.0",
|
47
|
+
"eslint-plugin-react-refresh": "^0.4.3",
|
48
|
+
"vite": "^6.3.5"
|
49
|
+
}
|
50
|
+
}
|