لینک‌های مفید برای شرکت در مسابقه:

در طول مسابقه می‌توانید سؤالات خود را از قسمت «سؤال بپرسید» مطرح کنید.

کانتکست‌ساز


روح‌الله در حال ساخت یک اپلیکیشن جدید است. او سعی دارد استیت‌های گلوبال اپلیکیشن خود را با کانتکست بنویسد، اما چون تنبل است، دوست ندارد هر بار این عمل را تکرار کند. تابعی به نام createGlobalState بنویسید که با گرفتن دستوراتی، این کار را برای او انجام دهد.

جزئیات پروژه🔗

پروژه‌ی اولیه را از این لینک دانلود کنید.

ساختار فایل‌های پروژه
context-maker
├── package.json
├── package-lock.json
├── public
│   └── index.html
├── README.md
└── src
    ├── App.js
    ├── contexts
    │   └── count.js
    ├── index.js
    ├── lib
    │   └── createGlobalState.js
    └── __tests__
        └── sample.test.js
Plain text
راه‌اندازی پروژه
  • پروژه‌ی اولیه را دانلود و از حالت فشرده خارج کنید.
  • با اجرای دستور npm i پکیج‌های مورد نیاز را نصب کنید.
  • با اجرای دستور npm start می‌توانید پروژه را اجرا کنید، اما توجه داشته باشید که تا قبل از تکمیل فایل ‍src/lib/createGlobalState.js، پروژه به درستی نمایش داده نمی‌شود.

تابع createGlobalState هر بار که روح‌الله بخواهد استیتی را با کانتکست ایجاد کند باید قابل استفاده باشد.

مثلاً اگر روح الله بخواهد استیتی به نام count را با کانتکست ایجاد کند، باید به شکل زیر بتواند این کار را انجام دهد:

extensionFromNamesrc/contexts/count.js
import { createGlobalState } from "../lib/createGlobalState";

const [CountProvider, useCount] = createGlobalState((set) => ({
  count: 0,
  increment(num) {
    set((count) => count + num);
  },
  decrementByOne() {
    set((count) => count - 1);
  },
  backToZero() {
    set(0);
  },
}));

export { CountProvider, useCount };
JavaScript

تابع createGlobalState به‌عنوان ورودی باید یک تابع بپذیرد. تابع ورودی نیز باید یک تابع دیگر به نام set دریافت کند.

تابعی که به createGlobalState پاس داده می‌شود باید یک آبجکت برگرداند که شامل نام استیت با مقدار اولیه‌ی دلخواه و تعدادی تابع به‌منظور ایجاد تغییر در استیت باشد.

تضمین می‌شود که در هر بار استفاده از createGlobalState، آبجکت فوق فقط دارای یک استیت باشد و مابقی پراپرتی‌ها توابعی برای تغییر همان استیت باشند.

توابعی که برای تغییر استیت تعریف می‌شوند باید بتوانند با استفاده از تابع set مقدار استیت را تغییر دهند.

نکته: تابع set دقیقاً مانند setter هوک useState رفتار می‌کند.

خروجی تابع createGlobalState باید یک آرایه باشد که این آرایه به‌ترتیب شامل یک کامپوننت Provider و یک هوک است.

کامپوننت Provider باید یک آبجکت، مشابه همان آبجکتی که در createGlobalState قرار دادیم را در قالب Context در دسترس فرزندانش قرار دهد.

فرزندان کامپوننت Provider باید بتوانند با استفاده از هوکی که از آرایه‌ی خروجی تابع createGlobalState دریافت می‌کنیم از مقدار Context استفاده کنند.

مثالی از نحوه‌ی استفاده از کامپوننت Provider:

extensionFromNameindex.js
import ReactDOM from "react-dom";
import App from "./App";
import { CountProvider } from "./contexts/count";

ReactDOM.render(
  <CountProvider>
    <App />
  </CountProvider>,
  document.getElementById("root")
);
React JSX

روح‌الله باید مجبور باشد از Provider مخصوص هر کانتکست استفاده کند. در غیر این‌صورت، باید یک ارور جدید از نوع آبجکت Error دریافت کند که باعث توقف در ادامه اجرای برنامه شود.

برای مثال اگر او بدون استفاده از CountProvider سعی کند از هوک useCount استفاده کند، باید چنین اروری را دریافت کند:

The 'count' global state must be used within it's relevant context provider
Plain text

نکته: متن دقیق ارور مهم نیست، اما حتماً باید شامل نام استیت باشد.

روح‌الله باید بتواند با استفاده هوکی که از آرایه‌ی خروجی تابع createGlobalState دریافت می‌کند به‌شکل زیر از مقدار استیت و توابعی که تعریف کرده بود استفاده کند:

extensionFromNameApp.js
import { useCount } from "./contexts/count";

function App() {

  const {count, increment, decrementByOne, backToZero} = useCount();

  return (
    <div>
      <h1>{count}</h1>
      <div>
        <button onClick={() => increment(5)}>
          Increment by 5
        </button>
        <button onClick={() => decrementByOne()}>
          Decrement by 1
        </button>
        <button onClick={() => backToZero()}>Back To Zero</button>
      </div>
    </div>
  );
}

export default App;
React JSX

نکته: بدیهی است که مثال count بالا فقط یک نمونه از نحوه‌ی کار تابع createGlobalState است. شما باید این تابع را طوری پیاده‌سازی کنید که با ورودی‌های متفاوت از جمله تفاوت در نام استیت، مقدار اولیه‌ی استیت و توابع مربوط به تغییر در استیت به درستی عمل کند.

توجه: شما تنها مجاز به اعمال تغییرات در فایل src/lib/createGlobalState.js هستید.

آن‌چه باید آپلود کنید🔗

پس از پیاده‌سازی موارد خواسته‌شده، پوشه‌ی src را زیپ کرده و آپلود کنید.

ارسال پاسخ برای این سؤال
در حال حاضر شما دسترسی ندارید.