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 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
+ ![screenshot](screenshot.png) <!-- 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}
@@ -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
+ }