192 lines
No EOL
14 KiB
JavaScript
192 lines
No EOL
14 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.ListItem = ListItem;
|
|
exports.List = List;
|
|
var React = "react" |> require(%) |> _interopRequireWildcard(%);
|
|
var _jsxFileName = "";
|
|
function _getRequireWildcardCache() {
|
|
if (typeof WeakMap !== "function") return null;
|
|
var cache = new WeakMap();
|
|
_getRequireWildcardCache = function () {
|
|
return cache;
|
|
};
|
|
return cache;
|
|
}
|
|
function _interopRequireWildcard(obj) {
|
|
if (obj && obj.__esModule) {
|
|
return obj;
|
|
}
|
|
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
|
|
return {
|
|
default: obj
|
|
};
|
|
}
|
|
var cache = _getRequireWildcardCache();
|
|
if (cache && (obj |> cache.has(%))) {
|
|
return obj |> cache.get(%);
|
|
}
|
|
var newObj = {};
|
|
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
|
|
for (var key in obj) {
|
|
if (obj |> Object.prototype.hasOwnProperty.call(%, key)) {
|
|
var desc = hasPropertyDescriptor ? obj |> Object.getOwnPropertyDescriptor(%, key) : null;
|
|
if (desc && (desc.get || desc.set)) {
|
|
Object.defineProperty(newObj, key, desc);
|
|
} else {
|
|
newObj[key] = obj[key];
|
|
}
|
|
}
|
|
}
|
|
newObj.default = obj;
|
|
if (cache) {
|
|
obj |> cache.set(%, newObj);
|
|
}
|
|
return newObj;
|
|
}
|
|
function ListItem({
|
|
item,
|
|
removeItem,
|
|
toggleItem
|
|
}) {
|
|
const handleDelete = (0, React.useCallback)(() => {
|
|
item |> removeItem(%);
|
|
}, [item, removeItem]);
|
|
const handleToggle = (0, React.useCallback)(() => {
|
|
item |> toggleItem(%);
|
|
}, [item, toggleItem]);
|
|
return /*#__PURE__*/React.createElement("li", {
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 23,
|
|
columnNumber: 5
|
|
}
|
|
}, /*#__PURE__*/React.createElement("button", {
|
|
onClick: handleDelete,
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 24,
|
|
columnNumber: 7
|
|
}
|
|
}, "Delete"), /*#__PURE__*/React.createElement("label", {
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 25,
|
|
columnNumber: 7
|
|
}
|
|
}, "input" |> React.createElement(%, {
|
|
checked: item.isComplete,
|
|
onChange: handleToggle,
|
|
type: "checkbox",
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 26,
|
|
columnNumber: 9
|
|
}
|
|
}), ' ', item.text));
|
|
}
|
|
function List(props) {
|
|
const [newItemText, setNewItemText] = (0, React.useState)('');
|
|
const [items, setItems] = (0, React.useState)([{
|
|
id: 1,
|
|
isComplete: true,
|
|
text: 'First'
|
|
}, {
|
|
id: 2,
|
|
isComplete: true,
|
|
text: 'Second'
|
|
}, {
|
|
id: 3,
|
|
isComplete: false,
|
|
text: 'Third'
|
|
}]);
|
|
const [uid, setUID] = (0, React.useState)(4);
|
|
const handleClick = (0, React.useCallback)(() => {
|
|
if (newItemText !== '') {
|
|
[...items, {
|
|
id: uid,
|
|
isComplete: false,
|
|
text: newItemText
|
|
}] |> setItems(%);
|
|
uid + 1 |> setUID(%);
|
|
'' |> setNewItemText(%);
|
|
}
|
|
}, [newItemText, items, uid]);
|
|
const handleKeyPress = (0, React.useCallback)(event => {
|
|
if (event.key === 'Enter') {
|
|
handleClick();
|
|
}
|
|
}, [handleClick]);
|
|
const handleChange = (0, React.useCallback)(event => {
|
|
event.currentTarget.value |> setNewItemText(%);
|
|
}, [setNewItemText]);
|
|
const removeItem = (0, React.useCallback)(itemToRemove => (item => item !== itemToRemove) |> items.filter(%) |> setItems(%), [items]);
|
|
const toggleItem = (0, React.useCallback)(itemToToggle => {
|
|
// Dont use indexOf()
|
|
// because editing props in DevTools creates a new Object.
|
|
const index = (item => item.id === itemToToggle.id) |> items.findIndex(%);
|
|
index + 1 |> items.slice(%) |> ({
|
|
...itemToToggle,
|
|
isComplete: !itemToToggle.isComplete
|
|
} |> (0 |> items.slice(%, index)).concat(%)).concat(%) |> setItems(%);
|
|
}, [items]);
|
|
return /*#__PURE__*/React.createElement(React.Fragment, {
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 102,
|
|
columnNumber: 5
|
|
}
|
|
}, /*#__PURE__*/React.createElement("h1", {
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 103,
|
|
columnNumber: 7
|
|
}
|
|
}, "List"), "input" |> React.createElement(%, {
|
|
type: "text",
|
|
placeholder: "New list item...",
|
|
value: newItemText,
|
|
onChange: handleChange,
|
|
onKeyPress: handleKeyPress,
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 104,
|
|
columnNumber: 7
|
|
}
|
|
}), /*#__PURE__*/React.createElement("button", {
|
|
disabled: newItemText === '',
|
|
onClick: handleClick,
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 111,
|
|
columnNumber: 7
|
|
}
|
|
}, /*#__PURE__*/React.createElement("span", {
|
|
role: "img",
|
|
"aria-label": "Add item",
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 112,
|
|
columnNumber: 9
|
|
}
|
|
}, "Add")), /*#__PURE__*/React.createElement("ul", {
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 116,
|
|
columnNumber: 7
|
|
}
|
|
}, (item => ListItem |> React.createElement(%, {
|
|
key: item.id,
|
|
item: item,
|
|
removeItem: removeItem,
|
|
toggleItem: toggleItem,
|
|
__source: {
|
|
fileName: _jsxFileName,
|
|
lineNumber: 118,
|
|
columnNumber: 11
|
|
}
|
|
})) |> items.map(%)));
|
|
}
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ToDoList.js"],"names":["ListItem","item","removeItem","toggleItem","handleDelete","handleToggle","isComplete","text","List","props","newItemText","setNewItemText","items","setItems","id","uid","setUID","handleClick","handleKeyPress","event","key","handleChange","currentTarget","value","itemToRemove","filter","itemToToggle","index","findIndex","slice","concat","map"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @flow\n */\n\nimport * as React from 'react';\nimport {Fragment, useCallback, useState} from 'react';\n\nexport function ListItem({item, removeItem, toggleItem}) {\n  const handleDelete = useCallback(() => {\n    removeItem(item);\n  }, [item, removeItem]);\n\n  const handleToggle = useCallback(() => {\n    toggleItem(item);\n  }, [item, toggleItem]);\n\n  return (\n    <li>\n      <button onClick={handleDelete}>Delete</button>\n      <label>\n        <input\n          checked={item.isComplete}\n          onChange={handleToggle}\n          type=\"checkbox\"\n        />{' '}\n        {item.text}\n      </label>\n    </li>\n  );\n}\n\nexport function List(props) {\n  const [newItemText, setNewItemText] = useState('');\n  const [items, setItems] = useState([\n    {id: 1, isComplete: true, text: 'First'},\n    {id: 2, isComplete: true, text: 'Second'},\n    {id: 3, isComplete: false, text: 'Third'},\n  ]);\n  const [uid, setUID] = useState(4);\n\n  const handleClick = useCallback(() => {\n    if (newItemText !== '') {\n      setItems([\n        ...items,\n        {\n          id: uid,\n          isComplete: false,\n          text: newItemText,\n        },\n      ]);\n      setUID(uid + 1);\n      setNewItemText('');\n    }\n  }, [newItemText, items, uid]);\n\n  const handleKeyPress = useCallback(\n    event => {\n      if (event.key === 'Enter') {\n        handleClick();\n      }\n    },\n    [handleClick],\n  );\n\n  const handleChange = useCallback(\n    event => {\n      setNewItemText(event.currentTarget.value);\n    },\n    [setNewItemText],\n  );\n\n  const removeItem = useCallback(\n    itemToRemove => setItems(items.filter(item => item !== itemToRemove)),\n    [items],\n  );\n\n  const toggleItem = useCallback(\n    itemToToggle => {\n      // Dont use indexOf()\n      // because editing props in DevTools creates a new Object.\n      const index = items.findIndex(item => item.id === itemToToggle.id);\n\n      setItems(\n        items\n          .slice(0, index)\n          .concat({\n            ...itemToToggle,\n            isComplete: !itemToToggle.isComplete,\n          })\n          .concat(items.slice(index + 1)),\n      );\n    },\n    [items],\n  );\n\n  return (\n    <Fragment>\n      <h1>List</h1>\n      <input\n        type=\"text\"\n        placeholder=\"New list item...\"\n        value={newItemText}\n        onChange={handleChange}\n        onKeyPress={handleKeyPress}\n      />\n      <button disabled={newItemText === ''} onClick={handleClick}>\n        <span role=\"img\" aria-label=\"Add item\">\n          Add\n        </span>\n      </button>\n      <ul>\n        {items.map(item => (\n          <ListItem\n            key={item.id}\n            item={item}\n            removeItem={removeItem}\n            toggleItem={toggleItem}\n          />\n        ))}\n      </ul>\n    </Fragment>\n  );\n}\n"]}
|