
ページ
アプリケーションルートによって定義されたトップレベルのコンポーネントを含みます。 それらは、モジュールフォルダからより低レベルのコンポーネントをインポートします(詳細は下記を参照)。モジュール
Each module represents a feature or a group of feature, comprising its specific components, states, and operational logic. 以下の構造に従う必要があります。 モジュール内にモジュール(サブモジュールとして参照)をネストし、同じルールが適用されます。コンテキスト
コンテキストは、各レベルでプロップスを手動で渡すことなく、コンポーネントツリーを通じてデータを渡す方法です。 詳細はReactコンテキストを参照してください。GraphQL
フラグメント、クエリ、およびミューテーションを含む。 詳細はGraphQLを参照してください。- フラグメント
- クエリ
- ミューテーション
フック
詳細はフックを参照してください。ステート
ステート管理ロジックを含みます。 これを管理するのはRecoilJSです。- セレクター: 詳細はRecoilJSセレクターを参照してください。
ユーティル
再利用可能な純粋関数のみを含むべきです。 それ以外の場合は、hooksフォルダにカスタムフックを作成します。
UI
アプリケーションで使用される再利用可能なUIコンポーネントをすべて含みます。 このフォルダには、特定のタイプのコンポーネント用にdata、display、feedback、およびinputのようなサブフォルダが含まれることがあります。 各コンポーネントは自己完結型で再利用可能でなければならず、アプリケーションのさまざまな部分で使用できます。
UIコンポーネントをmodulesフォルダ内の他のコンポーネントから分離することで、一貫したデザインを維持し、UIの変更がコードベースの他の部分(ビジネスロジック)に影響を与えないようにするのが容易になります。
インターフェースと依存関係
uiフォルダを除く任意のモジュールから他のモジュールコードをインポートできます。 これにより、そのコードは簡単にテストできます。
内部
各部分(フック、ステート、…) モジュールの一部はinternalフォルダを持ち、モジュール内でのみ使用される部分を含みます。