Home / File/ ListItem.js — react Source File

ListItem.js — react Source File

Architecture documentation for ListItem.js, a javascript file in the react codebase. 3 imports, 1 dependents.

File javascript BabelCompiler Validation 3 imports 1 dependents 3 functions

Entity Profile

Dependency Diagram

graph LR
  600c7a04_7bc8_1cb9_5303_8398c843ca05["ListItem.js"]
  dd025d14_7de6_e5db_ba26_add0e8a43a1e["ListItem.css"]
  600c7a04_7bc8_1cb9_5303_8398c843ca05 --> dd025d14_7de6_e5db_ba26_add0e8a43a1e
  5fd1ffe1_dc6c_f2c3_53aa_316f8da83850["List.js"]
  600c7a04_7bc8_1cb9_5303_8398c843ca05 --> 5fd1ffe1_dc6c_f2c3_53aa_316f8da83850
  ac587885_e294_a1e9_b13f_5e7b920fdb42["react"]
  600c7a04_7bc8_1cb9_5303_8398c843ca05 --> ac587885_e294_a1e9_b13f_5e7b920fdb42
  5fd1ffe1_dc6c_f2c3_53aa_316f8da83850["List.js"]
  5fd1ffe1_dc6c_f2c3_53aa_316f8da83850 --> 600c7a04_7bc8_1cb9_5303_8398c843ca05
  style 600c7a04_7bc8_1cb9_5303_8398c843ca05 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

/**
 * Copyright (c) Meta Platforms, Inc. and affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 *
 * @flow
 */

import * as React from 'react';
import {memo, useCallback} from 'react';
import styles from './ListItem.css';

import type {Item} from './List';

type Props = {
  item: Item,
  removeItem: (item: Item) => void,
  toggleItem: (item: Item) => void,
};

function ListItem({item, removeItem, toggleItem}: Props) {
  const handleDelete = useCallback(() => {
    removeItem(item);
  }, [item, removeItem]);

  const handleToggle = useCallback(() => {
    toggleItem(item);
  }, [item, toggleItem]);

  return (
    <li className={styles.ListItem}>
      <button className={styles.IconButton} onClick={handleDelete}>
        🗑
      </button>
      <label className={styles.Label}>
        <input
          className={styles.Input}
          checked={item.isComplete}
          onChange={handleToggle}
          type="checkbox"
        />{' '}
        {item.text}
      </label>
    </li>
  );
}

export default (memo(ListItem): component(...props: Props));

Domain

Subdomains

Dependencies

Frequently Asked Questions

What does ListItem.js do?
ListItem.js is a source file in the react codebase, written in javascript. It belongs to the BabelCompiler domain, Validation subdomain.
What functions are defined in ListItem.js?
ListItem.js defines 3 function(s): ListItem, type.removeItem, type.toggleItem.
What does ListItem.js depend on?
ListItem.js imports 3 module(s): List.js, ListItem.css, react.
What files import ListItem.js?
ListItem.js is imported by 1 file(s): List.js.
Where is ListItem.js in the architecture?
ListItem.js is located at packages/react-devtools-shell/src/app/ToDoList/ListItem.js (domain: BabelCompiler, subdomain: Validation, directory: packages/react-devtools-shell/src/app/ToDoList).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free