-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ReferenceError Cannot access 'xxx' before initialization #8878
Comments
Additional details: The reason seems to be that before https://stackoverflow.com/questions/48507803/es6-modules-why-can-i-use-a-const-before-it-is-declared Here's the whole file when it's compiled with a newer version of var C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0___namespace_cache;
__webpack_require__.r(__webpack_exports__);
/* harmony export */
__webpack_require__.d(__webpack_exports__, {
/* harmony export */
channelShape: ()=>(/* binding */
channelShape),
/* harmony export */
"default": ()=>(/* binding */
ChannelsListBase)/* harmony export */
});
/* harmony import */
var C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./node_modules/react-refresh/runtime.js */
"./node_modules/react-refresh/runtime.js");
/* harmony import */
var core_js_modules_web_dom_collections_iterator_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/web.dom-collections.iterator.js */
"./node_modules/core-js/modules/web.dom-collections.iterator.js");
/* harmony import */
var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react/jsx-runtime */
"./node_modules/react/jsx-runtime.js");
/* harmony import */
var react__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! react */
"./node_modules/react/index.js");
/* harmony import */
var prop_types__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! prop-types */
"./node_modules/prop-types/index.js");
/* harmony import */
var react_pages__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! react-pages */
"./node_modules/react-pages/lib/redux/Link.js");
/* harmony import */
var react_redux__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! react-redux */
"./node_modules/react-redux/dist/react-redux.mjs");
/* harmony import */
var react_responsive_ui__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! react-responsive-ui */
"./node_modules/react-responsive-ui/modules/Button.js");
/* harmony import */
var classnames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! classnames */
"./node_modules/classnames/index.js");
/* harmony import */
var _redux_settings_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../redux/settings.js */
"./src/redux/settings.js");
/* harmony import */
var _redux_data_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../redux/data.js */
"./src/redux/data.js");
/* harmony import */
var _hooks_useMessages_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../hooks/useMessages.js */
"./src/hooks/useMessages.js");
/* harmony import */
var _hooks_useSettings_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../../hooks/useSettings.js */
"./src/hooks/useSettings.js");
/* harmony import */
var _hooks_useDataSource_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../../hooks/useDataSource.js */
"./src/hooks/useDataSource.js");
/* harmony import */
var _hooks_useMultiDataSource_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../../hooks/useMultiDataSource.js */
"./src/hooks/useMultiDataSource.js");
/* harmony import */
var _ChannelsListSearch_js__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./ChannelsListSearch.js */
"./src/components/ChannelsList/ChannelsListSearch.js");
/* harmony import */
var _ChannelsListViewSwitcher_js__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./ChannelsListViewSwitcher.js */
"./src/components/ChannelsList/ChannelsListViewSwitcher.js");
/* harmony import */
var _ChannelsListBase_css__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./ChannelsListBase.css */
"./src/components/ChannelsList/ChannelsListBase.css");
/* provided dependency */
var __react_refresh_utils__ = __webpack_require__(/*! ./node_modules/@pmmmwh/react-refresh-webpack-plugin/lib/runtime/RefreshUtils.js */
"./node_modules/@pmmmwh/react-refresh-webpack-plugin/lib/runtime/RefreshUtils.js");
/* provided dependency */
var __react_refresh_error_overlay__ = __webpack_require__(/*! ./node_modules/@pmmmwh/react-refresh-webpack-plugin/overlay/index.js */
"./node_modules/@pmmmwh/react-refresh-webpack-plugin/overlay/index.js");
__webpack_require__.$Refresh$.runtime = /*#__PURE__*/
(C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0___namespace_cache || (C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0___namespace_cache = __webpack_require__.t(C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0__, 2)));
// `<Channels/>` are used in `pages/Channels.js`.
function ChannelsListBase(param) {
let {views, channels, channelsByPopularity, channelsByCategory, channelsView: channelsViewSetting, shouldSaveChannelsView, showAllChannels, showAllChannelsLink, listComponent: ListComponent, selectedChannel, highlightSelectedChannel, hasMoreChannels, className} = param;
const dispatch = (0,
react_redux__WEBPACK_IMPORTED_MODULE_14__.useDispatch)();
const messages = (0,
_hooks_useMessages_js__WEBPACK_IMPORTED_MODULE_7__["default"])();
const userSettings = (0,
_hooks_useSettings_js__WEBPACK_IMPORTED_MODULE_8__["default"])();
const dataSource = (0,
_hooks_useDataSource_js__WEBPACK_IMPORTED_MODULE_9__["default"])();
const multiDataSource = (0,
_hooks_useMultiDataSource_js__WEBPACK_IMPORTED_MODULE_10__["default"])();
const [filteredChannels,setFilteredChannels] = (0,
react__WEBPACK_IMPORTED_MODULE_3__.useState)();
const [view,setView] = (0,
react__WEBPACK_IMPORTED_MODULE_3__.useState)();
const defaultChannelsView = getChannelsView(channelsViewSetting, {
canViewByCategory: Boolean(channelsByCategory) && views && views.includes("by-category"),
canViewByPopularity: Boolean(channelsByPopularity)
});
const channelsView = view || defaultChannelsView;
const onViewChange = (0,
react__WEBPACK_IMPORTED_MODULE_3__.useCallback)((view)=>{
setView(view);
if (shouldSaveChannelsView) {
dispatch((0,
_redux_settings_js__WEBPACK_IMPORTED_MODULE_5__.saveChannelsView)({
channelsView: view,
userSettings
}));
}
}
, [dispatch]);
const isChannelSelected = (0,
react__WEBPACK_IMPORTED_MODULE_3__.useCallback)((channel)=>{
return highlightSelectedChannel && selectedChannel && channel.id === selectedChannel.id;
}
, [highlightSelectedChannel, selectedChannel]);
const getChannelsListItems = (0,
react__WEBPACK_IMPORTED_MODULE_3__.useCallback)(()=>{
switch (channelsView) {
case "by-category":
return channelsByCategory.reduce((all,category,i)=>{
return all.concat([{
key: category.category || "—",
category: category.category,
first: i === 0
}]).concat(category.channels.map((channel)=>({
key: channel.id,
channel,
selected: isChannelSelected(channel)
})));
}
, []);
case "list":
return (filteredChannels || channelsByPopularity || channels).filter((channel)=>showAllChannels || !channel.isHidden).map((channel)=>({
key: channel.id,
channel,
selected: isChannelSelected(channel)
}));
default:
// Unsupported `channelsView`.
return [];
}
}
, [channelsView, channels, channelsByPopularity, channelsByCategory, filteredChannels, isChannelSelected, showAllChannels]);
const loadChannelsList = (0,
react__WEBPACK_IMPORTED_MODULE_3__.useCallback)(async()=>{
await dispatch((0,
_redux_data_js__WEBPACK_IMPORTED_MODULE_6__.getChannels)({
userSettings,
dataSource,
multiDataSource,
messages
}));
}
, [dispatch, userSettings, dataSource, multiDataSource, messages]);
if (!channels) {
return /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsxs)("p", {
className: "Channels-error",
children: [/*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)("span", {
className: "Channels-errorText",
children: messages.boards.error
}), /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)("br", {}), /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)(react_responsive_ui__WEBPACK_IMPORTED_MODULE_15__["default"], {
className: "Channels-errorRetry",
onClick: loadChannelsList,
children: messages.actions.retry
})]
});
}
return /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsxs)("nav", {
className: "Channels",
children: [views && views.includes("list") && channelsByPopularity && channelsByCategory && views.includes("by-category") && /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)(_ChannelsListViewSwitcher_js__WEBPACK_IMPORTED_MODULE_12__["default"], {
view: channelsView,
onViewChange: onViewChange
}), showAllChannels && channelsView === "list" && /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)(_ChannelsListSearch_js__WEBPACK_IMPORTED_MODULE_11__["default"], {
channels: channels || channelsByPopularity,
setSearchResults: setFilteredChannels
}), /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)(ListComponent, {
className: classnames__WEBPACK_IMPORTED_MODULE_4__("Channels-list", {
// 'Channels-list--list': channelsView === 'list',
"Channels-list--by-category": channelsView === "by-category"
}),
children: getChannelsListItems()
}), !showAllChannels && showAllChannelsLink && (hasMoreChannels || dataSource.contentCategoryUnspecified) && /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)("div", {
className: "Channels-showAllWrapper",
children: /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_2__.jsx)(react_pages__WEBPACK_IMPORTED_MODULE_16__["default"], {
to: "/channels",
className: "Channels-showAll",
children: messages.boards.showAll
})
})]
});
}
const channelShape = {
id: prop_types__WEBPACK_IMPORTED_MODULE_17__.string.isRequired,
title: prop_types__WEBPACK_IMPORTED_MODULE_17__.string.isRequired,
description: prop_types__WEBPACK_IMPORTED_MODULE_17__.string,
commentsPerHour: prop_types__WEBPACK_IMPORTED_MODULE_17__.number
};
ChannelsListBase.propTypes = {
views: prop_types__WEBPACK_IMPORTED_MODULE_17__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_17__.oneOf(["list", "by-category"])),
channels: prop_types__WEBPACK_IMPORTED_MODULE_17__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_17__.shape(channelShape)),
channelsByPopularity: prop_types__WEBPACK_IMPORTED_MODULE_17__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_17__.shape(channelShape)),
channelsByCategory: prop_types__WEBPACK_IMPORTED_MODULE_17__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_17__.shape({
category: prop_types__WEBPACK_IMPORTED_MODULE_17__.string.isRequired,
channels: prop_types__WEBPACK_IMPORTED_MODULE_17__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_17__.shape(channelShape)).isRequired
})),
channelsView: prop_types__WEBPACK_IMPORTED_MODULE_17__.string,
shouldSaveChannelsView: prop_types__WEBPACK_IMPORTED_MODULE_17__.bool,
showAllChannels: prop_types__WEBPACK_IMPORTED_MODULE_17__.bool,
showAllChannelsLink: prop_types__WEBPACK_IMPORTED_MODULE_17__.bool,
selectedChannel: prop_types__WEBPACK_IMPORTED_MODULE_17__.shape(channelShape),
highlightSelectedChannel: prop_types__WEBPACK_IMPORTED_MODULE_17__.bool,
// isChannelOrThreadLocation: PropTypes.bool,
hasMoreChannels: prop_types__WEBPACK_IMPORTED_MODULE_17__.bool,
// dispatch: PropTypes.func,
listComponent: prop_types__WEBPACK_IMPORTED_MODULE_17__.elementType.isRequired,
className: prop_types__WEBPACK_IMPORTED_MODULE_17__.string
};
function getChannelsView(channelsView, param) {
let {canViewByCategory, canViewByPopularity} = param;
switch (channelsView) {
case "by-category":
if (canViewByCategory) {
return channelsView;
}
case "list":
return channelsView;
}
if (canViewByPopularity) {
return "list";
}
if (canViewByCategory) {
return "by-category";
}
return "list";
}
const $ReactRefreshModuleId$ = __webpack_require__.$Refresh$.moduleId;
const $ReactRefreshCurrentExports$ = __react_refresh_utils__.getModuleExports($ReactRefreshModuleId$);
function $ReactRefreshModuleRuntime$(exports) {
if (true) {
let errorOverlay;
if (typeof __react_refresh_error_overlay__ !== 'undefined') {
errorOverlay = __react_refresh_error_overlay__;
}
let testMode;
if (typeof __react_refresh_test__ !== 'undefined') {
testMode = __react_refresh_test__;
}
return __react_refresh_utils__.executeRuntime(exports, $ReactRefreshModuleId$, __webpack_module__.hot, errorOverlay, testMode);
}
}
if (typeof Promise !== 'undefined' && $ReactRefreshCurrentExports$ instanceof Promise) {
$ReactRefreshCurrentExports$.then($ReactRefreshModuleRuntime$);
} else {
$ReactRefreshModuleRuntime$($ReactRefreshCurrentExports$);
}
//# sourceURL=[module]
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/components/ChannelsList/ChannelsListBase.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://anychan/./src/components/ChannelsList/ChannelsListBase.js?b2a3"],"sourcesContent":["import * as __react_refresh_runtime__ from 'C:/dev/anychan/node_modules/react-refresh/runtime.js';\n__webpack_require__.$Refresh$.runtime = __react_refresh_runtime__;\n\nimport \"core-js/modules/web.dom-collections.iterator.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useState, useCallback } from \"react\";\nimport PropTypes from \"prop-types\";\nimport { Link } from \"react-pages\";\nimport { useDispatch } from \"react-redux\";\nimport { Button } from \"react-responsive-ui\";\nimport classNames from \"classnames\";\nimport { saveChannelsView } from \"../../redux/settings.js\";\nimport { getChannels } from \"../../redux/data.js\";\nimport useMessages from \"../../hooks/useMessages.js\";\nimport useSettings from \"../../hooks/useSettings.js\";\nimport useDataSource from \"../../hooks/useDataSource.js\";\nimport useMultiDataSource from \"../../hooks/useMultiDataSource.js\";\nimport ChannelsListSearch from \"./ChannelsListSearch.js\";\nimport ChannelsListViewSwitcher from \"./ChannelsListViewSwitcher.js\";\nimport \"./ChannelsListBase.css\";\n// `<Channels/>` are used in `pages/Channels.js`.\nexport default function ChannelsListBase(param) {\n    let { views, channels, channelsByPopularity, channelsByCategory, channelsView: channelsViewSetting, shouldSaveChannelsView, showAllChannels, showAllChannelsLink, listComponent: ListComponent, selectedChannel, highlightSelectedChannel, hasMoreChannels, className } = param;\n    const dispatch = useDispatch();\n    const messages = useMessages();\n    const userSettings = useSettings();\n    const dataSource = useDataSource();\n    const multiDataSource = useMultiDataSource();\n    const [filteredChannels, setFilteredChannels] = useState();\n    const [view, setView] = useState();\n    const defaultChannelsView = getChannelsView(channelsViewSetting, {\n        canViewByCategory: Boolean(channelsByCategory) && views && views.includes(\"by-category\"),\n        canViewByPopularity: Boolean(channelsByPopularity)\n    });\n    const channelsView = view || defaultChannelsView;\n    const onViewChange = useCallback((view)=>{\n        setView(view);\n        if (shouldSaveChannelsView) {\n            dispatch(saveChannelsView({\n                channelsView: view,\n                userSettings\n            }));\n        }\n    }, [\n        dispatch\n    ]);\n    const isChannelSelected = useCallback((channel)=>{\n        return highlightSelectedChannel && selectedChannel && channel.id === selectedChannel.id;\n    }, [\n        highlightSelectedChannel,\n        selectedChannel\n    ]);\n    const getChannelsListItems = useCallback(()=>{\n        switch(channelsView){\n            case \"by-category\":\n                return channelsByCategory.reduce((all, category, i)=>{\n                    return all.concat([\n                        {\n                            key: category.category || \"—\",\n                            category: category.category,\n                            first: i === 0\n                        }\n                    ]).concat(category.channels.map((channel)=>({\n                            key: channel.id,\n                            channel,\n                            selected: isChannelSelected(channel)\n                        })));\n                }, []);\n            case \"list\":\n                return (filteredChannels || channelsByPopularity || channels).filter((channel)=>showAllChannels || !channel.isHidden).map((channel)=>({\n                        key: channel.id,\n                        channel,\n                        selected: isChannelSelected(channel)\n                    }));\n            default:\n                // Unsupported `channelsView`.\n                return [];\n        }\n    }, [\n        channelsView,\n        channels,\n        channelsByPopularity,\n        channelsByCategory,\n        filteredChannels,\n        isChannelSelected,\n        showAllChannels\n    ]);\n    const loadChannelsList = useCallback(async ()=>{\n        await dispatch(getChannels({\n            userSettings,\n            dataSource,\n            multiDataSource,\n            messages\n        }));\n    }, [\n        dispatch,\n        userSettings,\n        dataSource,\n        multiDataSource,\n        messages\n    ]);\n    if (!channels) {\n        return /*#__PURE__*/ _jsxs(\"p\", {\n            className: \"Channels-error\",\n            children: [\n                /*#__PURE__*/ _jsx(\"span\", {\n                    className: \"Channels-errorText\",\n                    children: messages.boards.error\n                }),\n                /*#__PURE__*/ _jsx(\"br\", {}),\n                /*#__PURE__*/ _jsx(Button, {\n                    className: \"Channels-errorRetry\",\n                    onClick: loadChannelsList,\n                    children: messages.actions.retry\n                })\n            ]\n        });\n    }\n    return /*#__PURE__*/ _jsxs(\"nav\", {\n        className: \"Channels\",\n        children: [\n            views && views.includes(\"list\") && channelsByPopularity && channelsByCategory && views.includes(\"by-category\") && /*#__PURE__*/ _jsx(ChannelsListViewSwitcher, {\n                view: channelsView,\n                onViewChange: onViewChange\n            }),\n            showAllChannels && channelsView === \"list\" && /*#__PURE__*/ _jsx(ChannelsListSearch, {\n                channels: channels || channelsByPopularity,\n                setSearchResults: setFilteredChannels\n            }),\n            /*#__PURE__*/ _jsx(ListComponent, {\n                className: classNames(\"Channels-list\", {\n                    // 'Channels-list--list': channelsView === 'list',\n                    \"Channels-list--by-category\": channelsView === \"by-category\"\n                }),\n                children: getChannelsListItems()\n            }),\n            !showAllChannels && showAllChannelsLink && (hasMoreChannels || dataSource.contentCategoryUnspecified) && /*#__PURE__*/ _jsx(\"div\", {\n                className: \"Channels-showAllWrapper\",\n                children: /*#__PURE__*/ _jsx(Link, {\n                    to: \"/channels\",\n                    className: \"Channels-showAll\",\n                    children: messages.boards.showAll\n                })\n            })\n        ]\n    });\n}\nexport const channelShape = {\n    id: PropTypes.string.isRequired,\n    title: PropTypes.string.isRequired,\n    description: PropTypes.string,\n    commentsPerHour: PropTypes.number\n};\nChannelsListBase.propTypes = {\n    views: PropTypes.arrayOf(PropTypes.oneOf([\n        \"list\",\n        \"by-category\"\n    ])),\n    channels: PropTypes.arrayOf(PropTypes.shape(channelShape)),\n    channelsByPopularity: PropTypes.arrayOf(PropTypes.shape(channelShape)),\n    channelsByCategory: PropTypes.arrayOf(PropTypes.shape({\n        category: PropTypes.string.isRequired,\n        channels: PropTypes.arrayOf(PropTypes.shape(channelShape)).isRequired\n    })),\n    channelsView: PropTypes.string,\n    shouldSaveChannelsView: PropTypes.bool,\n    showAllChannels: PropTypes.bool,\n    showAllChannelsLink: PropTypes.bool,\n    selectedChannel: PropTypes.shape(channelShape),\n    highlightSelectedChannel: PropTypes.bool,\n    // isChannelOrThreadLocation: PropTypes.bool,\n    hasMoreChannels: PropTypes.bool,\n    // dispatch: PropTypes.func,\n    listComponent: PropTypes.elementType.isRequired,\n    className: PropTypes.string\n};\nfunction getChannelsView(channelsView, param) {\n    let { canViewByCategory, canViewByPopularity } = param;\n    switch(channelsView){\n        case \"by-category\":\n            if (canViewByCategory) {\n                return channelsView;\n            }\n        case \"list\":\n            return channelsView;\n    }\n    if (canViewByPopularity) {\n        return \"list\";\n    }\n    if (canViewByCategory) {\n        return \"by-category\";\n    }\n    return \"list\";\n}\n\n\nconst $ReactRefreshModuleId$ = __webpack_require__.$Refresh$.moduleId;\nconst $ReactRefreshCurrentExports$ = __react_refresh_utils__.getModuleExports(\n\t$ReactRefreshModuleId$\n);\n\nfunction $ReactRefreshModuleRuntime$(exports) {\n\tif (import.meta.webpackHot) {\n\t\tlet errorOverlay;\n\t\tif (typeof __react_refresh_error_overlay__ !== 'undefined') {\n\t\t\terrorOverlay = __react_refresh_error_overlay__;\n\t\t}\n\t\tlet testMode;\n\t\tif (typeof __react_refresh_test__ !== 'undefined') {\n\t\t\ttestMode = __react_refresh_test__;\n\t\t}\n\t\treturn __react_refresh_utils__.executeRuntime(\n\t\t\texports,\n\t\t\t$ReactRefreshModuleId$,\n\t\t\timport.meta.webpackHot,\n\t\t\terrorOverlay,\n\t\t\ttestMode\n\t\t);\n\t}\n}\n\nif (typeof Promise !== 'undefined' && $ReactRefreshCurrentExports$ instanceof Promise) {\n\t$ReactRefreshCurrentExports$.then($ReactRefreshModuleRuntime$);\n} else {\n\t$ReactRefreshModuleRuntime$($ReactRefreshCurrentExports$);\n}"],"names":[],"sourceRoot":""}
//# sourceURL=webpack-internal:///./src/components/ChannelsList/ChannelsListBase.js Here's the whole file when it's compiled with an older version of var C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0___namespace_cache;
__webpack_require__.r(__webpack_exports__);
/* harmony export */
__webpack_require__.d(__webpack_exports__, {
/* harmony export */
channelShape: ()=>(/* binding */
channelShape),
/* harmony export */
"default": ()=>(/* binding */
ChannelsListBase)/* harmony export */
});
/* harmony import */
var C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./node_modules/react-refresh/runtime.js */
"./node_modules/react-refresh/runtime.js");
/* harmony import */
var core_js_modules_es_array_includes_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/es.array.includes.js */
"./node_modules/core-js/modules/es.array.includes.js");
/* harmony import */
var core_js_modules_es_string_includes_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core-js/modules/es.string.includes.js */
"./node_modules/core-js/modules/es.string.includes.js");
/* harmony import */
var core_js_modules_es_array_reduce_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core-js/modules/es.array.reduce.js */
"./node_modules/core-js/modules/es.array.reduce.js");
/* harmony import */
var core_js_modules_es_object_to_string_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! core-js/modules/es.object.to-string.js */
"./node_modules/core-js/modules/es.object.to-string.js");
/* harmony import */
var core_js_modules_es_array_concat_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! core-js/modules/es.array.concat.js */
"./node_modules/core-js/modules/es.array.concat.js");
/* harmony import */
var core_js_modules_es_array_map_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! core-js/modules/es.array.map.js */
"./node_modules/core-js/modules/es.array.map.js");
/* harmony import */
var core_js_modules_es_array_filter_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! core-js/modules/es.array.filter.js */
"./node_modules/core-js/modules/es.array.filter.js");
/* harmony import */
var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! react/jsx-runtime */
"./node_modules/react/jsx-runtime.js");
/* harmony import */
var react__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! react */
"./node_modules/react/index.js");
/* harmony import */
var prop_types__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(/*! prop-types */
"./node_modules/prop-types/index.js");
/* harmony import */
var react_pages__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! react-pages */
"./node_modules/react-pages/lib/redux/Link.js");
/* harmony import */
var react_redux__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! react-redux */
"./node_modules/react-redux/dist/react-redux.mjs");
/* harmony import */
var react_responsive_ui__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! react-responsive-ui */
"./node_modules/react-responsive-ui/modules/Button.js");
/* harmony import */
var classnames__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! classnames */
"./node_modules/classnames/index.js");
/* harmony import */
var _redux_settings_js__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../../redux/settings.js */
"./src/redux/settings.js");
/* harmony import */
var _redux_data_js__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../../redux/data.js */
"./src/redux/data.js");
/* harmony import */
var _hooks_useMessages_js__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../../hooks/useMessages.js */
"./src/hooks/useMessages.js");
/* harmony import */
var _hooks_useSettings_js__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../../hooks/useSettings.js */
"./src/hooks/useSettings.js");
/* harmony import */
var _hooks_useDataSource_js__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ../../hooks/useDataSource.js */
"./src/hooks/useDataSource.js");
/* harmony import */
var _hooks_useMultiDataSource_js__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ../../hooks/useMultiDataSource.js */
"./src/hooks/useMultiDataSource.js");
/* harmony import */
var _ChannelsListSearch_js__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ./ChannelsListSearch.js */
"./src/components/ChannelsList/ChannelsListSearch.js");
/* harmony import */
var _ChannelsListViewSwitcher_js__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! ./ChannelsListViewSwitcher.js */
"./src/components/ChannelsList/ChannelsListViewSwitcher.js");
/* harmony import */
var _ChannelsListBase_css__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! ./ChannelsListBase.css */
"./src/components/ChannelsList/ChannelsListBase.css");
/* provided dependency */
var __react_refresh_utils__ = __webpack_require__(/*! ./node_modules/@pmmmwh/react-refresh-webpack-plugin/lib/runtime/RefreshUtils.js */
"./node_modules/@pmmmwh/react-refresh-webpack-plugin/lib/runtime/RefreshUtils.js");
/* provided dependency */
var __react_refresh_error_overlay__ = __webpack_require__(/*! ./node_modules/@pmmmwh/react-refresh-webpack-plugin/overlay/index.js */
"./node_modules/@pmmmwh/react-refresh-webpack-plugin/overlay/index.js");
__webpack_require__.$Refresh$.runtime = /*#__PURE__*/
(C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0___namespace_cache || (C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0___namespace_cache = __webpack_require__.t(C_dev_anychan_node_modules_react_refresh_runtime_js__WEBPACK_IMPORTED_MODULE_0__, 2)));
function _array_like_to_array(arr, len) {
if (len == null || len > arr.length)
len = arr.length;
for (var i = 0, arr2 = new Array(len); i < len; i++)
arr2[i] = arr[i];
return arr2;
}
function _array_with_holes(arr) {
if (Array.isArray(arr))
return arr;
}
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
try {
var info = gen[key](arg);
var value = info.value;
} catch (error) {
reject(error);
return;
}
if (info.done) {
resolve(value);
} else {
Promise.resolve(value).then(_next, _throw);
}
}
function _async_to_generator(fn) {
return function() {
var self = this
, args = arguments;
return new Promise(function(resolve, reject) {
var gen = fn.apply(self, args);
function _next(value) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
}
function _throw(err) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
}
_next(undefined);
}
);
}
;
}
function _iterable_to_array_limit(arr, i) {
var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
if (_i == null)
return;
var _arr = [];
var _n = true;
var _d = false;
var _s, _e;
try {
for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
_arr.push(_s.value);
if (i && _arr.length === i)
break;
}
} catch (err) {
_d = true;
_e = err;
} finally {
try {
if (!_n && _i["return"] != null)
_i["return"]();
} finally {
if (_d)
throw _e;
}
}
return _arr;
}
function _non_iterable_rest() {
throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
function _sliced_to_array(arr, i) {
return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
}
function _unsupported_iterable_to_array(o, minLen) {
if (!o)
return;
if (typeof o === "string")
return _array_like_to_array(o, minLen);
var n = Object.prototype.toString.call(o).slice(8, -1);
if (n === "Object" && o.constructor)
n = o.constructor.name;
if (n === "Map" || n === "Set")
return Array.from(n);
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))
return _array_like_to_array(o, minLen);
}
function _ts_generator(thisArg, body) {
var f, y, t, g, _ = {
label: 0,
sent: function() {
if (t[0] & 1)
throw t[1];
return t[1];
},
trys: [],
ops: []
};
return g = {
next: verb(0),
"throw": verb(1),
"return": verb(2)
},
typeof Symbol === "function" && (g[Symbol.iterator] = function() {
return this;
}
),
g;
function verb(n) {
return function(v) {
return step([n, v]);
}
;
}
function step(op) {
if (f)
throw new TypeError("Generator is already executing.");
while (_)
try {
if (f = 1,
y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y),
0) : y.next) && !(t = t.call(y, op[1])).done)
return t;
if (y = 0,
t)
op = [op[0] & 2, t.value];
switch (op[0]) {
case 0:
case 1:
t = op;
break;
case 4:
_.label++;
return {
value: op[1],
done: false
};
case 5:
_.label++;
y = op[1];
op = [0];
continue;
case 7:
op = _.ops.pop();
_.trys.pop();
continue;
default:
if (!(t = _.trys,
t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
_ = 0;
continue;
}
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
_.label = op[1];
break;
}
if (op[0] === 6 && _.label < t[1]) {
_.label = t[1];
t = op;
break;
}
if (t && _.label < t[2]) {
_.label = t[2];
_.ops.push(op);
break;
}
if (t[2])
_.ops.pop();
_.trys.pop();
continue;
}
op = body.call(thisArg, _);
} catch (e) {
op = [6, e];
y = 0;
} finally {
f = t = 0;
}
if (op[0] & 5)
throw op[1];
return {
value: op[0] ? op[1] : void 0,
done: true
};
}
}
// `<Channels/>` are used in `pages/Channels.js`.
function ChannelsListBase(param) {
var views = param.views
, channels = param.channels
, channelsByPopularity = param.channelsByPopularity
, channelsByCategory = param.channelsByCategory
, channelsViewSetting = param.channelsView
, shouldSaveChannelsView = param.shouldSaveChannelsView
, showAllChannels = param.showAllChannels
, showAllChannelsLink = param.showAllChannelsLink
, ListComponent = param.listComponent
, selectedChannel = param.selectedChannel
, highlightSelectedChannel = param.highlightSelectedChannel
, hasMoreChannels = param.hasMoreChannels
, className = param.className;
var dispatch = (0,
react_redux__WEBPACK_IMPORTED_MODULE_20__.useDispatch)();
var messages = (0,
_hooks_useMessages_js__WEBPACK_IMPORTED_MODULE_13__["default"])();
var userSettings = (0,
_hooks_useSettings_js__WEBPACK_IMPORTED_MODULE_14__["default"])();
var dataSource = (0,
_hooks_useDataSource_js__WEBPACK_IMPORTED_MODULE_15__["default"])();
var multiDataSource = (0,
_hooks_useMultiDataSource_js__WEBPACK_IMPORTED_MODULE_16__["default"])();
var _useState = _sliced_to_array((0,
react__WEBPACK_IMPORTED_MODULE_9__.useState)(), 2)
, filteredChannels = _useState[0]
, setFilteredChannels = _useState[1];
var _useState1 = _sliced_to_array((0,
react__WEBPACK_IMPORTED_MODULE_9__.useState)(), 2)
, view = _useState1[0]
, setView = _useState1[1];
var defaultChannelsView = getChannelsView(channelsViewSetting, {
canViewByCategory: Boolean(channelsByCategory) && views && views.includes("by-category"),
canViewByPopularity: Boolean(channelsByPopularity)
});
var channelsView = view || defaultChannelsView;
var onViewChange = (0,
react__WEBPACK_IMPORTED_MODULE_9__.useCallback)(function(view) {
setView(view);
if (shouldSaveChannelsView) {
dispatch((0,
_redux_settings_js__WEBPACK_IMPORTED_MODULE_11__.saveChannelsView)({
channelsView: view,
userSettings: userSettings
}));
}
}, [dispatch]);
var isChannelSelected = (0,
react__WEBPACK_IMPORTED_MODULE_9__.useCallback)(function(channel) {
return highlightSelectedChannel && selectedChannel && channel.id === selectedChannel.id;
}, [highlightSelectedChannel, selectedChannel]);
var getChannelsListItems = (0,
react__WEBPACK_IMPORTED_MODULE_9__.useCallback)(function() {
switch (channelsView) {
case "by-category":
return channelsByCategory.reduce(function(all, category, i) {
return all.concat([{
key: category.category || "—",
category: category.category,
first: i === 0
}]).concat(category.channels.map(function(channel) {
return {
key: channel.id,
channel: channel,
selected: isChannelSelected(channel)
};
}));
}, []);
case "list":
return (filteredChannels || channelsByPopularity || channels).filter(function(channel) {
return showAllChannels || !channel.isHidden;
}).map(function(channel) {
return {
key: channel.id,
channel: channel,
selected: isChannelSelected(channel)
};
});
default:
// Unsupported `channelsView`.
return [];
}
}, [channelsView, channels, channelsByPopularity, channelsByCategory, filteredChannels, isChannelSelected, showAllChannels]);
var loadChannelsList = (0,
react__WEBPACK_IMPORTED_MODULE_9__.useCallback)(/*#__PURE__*/
_async_to_generator(function() {
return _ts_generator(this, function(_state) {
switch (_state.label) {
case 0:
return [4, dispatch((0,
_redux_data_js__WEBPACK_IMPORTED_MODULE_12__.getChannels)({
userSettings: userSettings,
dataSource: dataSource,
multiDataSource: multiDataSource,
messages: messages
}))];
case 1:
_state.sent();
return [2];
}
});
}), [dispatch, userSettings, dataSource, multiDataSource, messages]);
if (!channels) {
return /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsxs)("p", {
className: "Channels-error",
children: [/*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)("span", {
className: "Channels-errorText",
children: messages.boards.error
}), /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)("br", {}), /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)(react_responsive_ui__WEBPACK_IMPORTED_MODULE_21__["default"], {
className: "Channels-errorRetry",
onClick: loadChannelsList,
children: messages.actions.retry
})]
});
}
return /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsxs)("nav", {
className: "Channels",
children: [views && views.includes("list") && channelsByPopularity && channelsByCategory && views.includes("by-category") && /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)(_ChannelsListViewSwitcher_js__WEBPACK_IMPORTED_MODULE_18__["default"], {
view: channelsView,
onViewChange: onViewChange
}), showAllChannels && channelsView === "list" && /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)(_ChannelsListSearch_js__WEBPACK_IMPORTED_MODULE_17__["default"], {
channels: channels || channelsByPopularity,
setSearchResults: setFilteredChannels
}), /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)(ListComponent, {
className: classnames__WEBPACK_IMPORTED_MODULE_10__("Channels-list", {
// 'Channels-list--list': channelsView === 'list',
"Channels-list--by-category": channelsView === "by-category"
}),
children: getChannelsListItems()
}), !showAllChannels && showAllChannelsLink && (hasMoreChannels || dataSource.contentCategoryUnspecified) && /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)("div", {
className: "Channels-showAllWrapper",
children: /*#__PURE__*/
(0,
react_jsx_runtime__WEBPACK_IMPORTED_MODULE_8__.jsx)(react_pages__WEBPACK_IMPORTED_MODULE_22__["default"], {
to: "/channels",
className: "Channels-showAll",
children: messages.boards.showAll
})
})]
});
}
var channelShape = {
id: prop_types__WEBPACK_IMPORTED_MODULE_23__.string.isRequired,
title: prop_types__WEBPACK_IMPORTED_MODULE_23__.string.isRequired,
description: prop_types__WEBPACK_IMPORTED_MODULE_23__.string,
commentsPerHour: prop_types__WEBPACK_IMPORTED_MODULE_23__.number
};
ChannelsListBase.propTypes = {
views: prop_types__WEBPACK_IMPORTED_MODULE_23__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_23__.oneOf(["list", "by-category"])),
channels: prop_types__WEBPACK_IMPORTED_MODULE_23__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_23__.shape(channelShape)),
channelsByPopularity: prop_types__WEBPACK_IMPORTED_MODULE_23__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_23__.shape(channelShape)),
channelsByCategory: prop_types__WEBPACK_IMPORTED_MODULE_23__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_23__.shape({
category: prop_types__WEBPACK_IMPORTED_MODULE_23__.string.isRequired,
channels: prop_types__WEBPACK_IMPORTED_MODULE_23__.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_23__.shape(channelShape)).isRequired
})),
channelsView: prop_types__WEBPACK_IMPORTED_MODULE_23__.string,
shouldSaveChannelsView: prop_types__WEBPACK_IMPORTED_MODULE_23__.bool,
showAllChannels: prop_types__WEBPACK_IMPORTED_MODULE_23__.bool,
showAllChannelsLink: prop_types__WEBPACK_IMPORTED_MODULE_23__.bool,
selectedChannel: prop_types__WEBPACK_IMPORTED_MODULE_23__.shape(channelShape),
highlightSelectedChannel: prop_types__WEBPACK_IMPORTED_MODULE_23__.bool,
// isChannelOrThreadLocation: PropTypes.bool,
hasMoreChannels: prop_types__WEBPACK_IMPORTED_MODULE_23__.bool,
// dispatch: PropTypes.func,
listComponent: prop_types__WEBPACK_IMPORTED_MODULE_23__.elementType.isRequired,
className: prop_types__WEBPACK_IMPORTED_MODULE_23__.string
};
function getChannelsView(channelsView, param) {
var canViewByCategory = param.canViewByCategory
, canViewByPopularity = param.canViewByPopularity;
switch (channelsView) {
case "by-category":
if (canViewByCategory) {
return channelsView;
}
case "list":
return channelsView;
}
if (canViewByPopularity) {
return "list";
}
if (canViewByCategory) {
return "by-category";
}
return "list";
}
const $ReactRefreshModuleId$ = __webpack_require__.$Refresh$.moduleId;
const $ReactRefreshCurrentExports$ = __react_refresh_utils__.getModuleExports($ReactRefreshModuleId$);
function $ReactRefreshModuleRuntime$(exports) {
if (true) {
let errorOverlay;
if (typeof __react_refresh_error_overlay__ !== 'undefined') {
errorOverlay = __react_refresh_error_overlay__;
}
let testMode;
if (typeof __react_refresh_test__ !== 'undefined') {
testMode = __react_refresh_test__;
}
return __react_refresh_utils__.executeRuntime(exports, $ReactRefreshModuleId$, __webpack_module__.hot, errorOverlay, testMode);
}
}
if (typeof Promise !== 'undefined' && $ReactRefreshCurrentExports$ instanceof Promise) {
$ReactRefreshCurrentExports$.then($ReactRefreshModuleRuntime$);
} else {
$ReactRefreshModuleRuntime$($ReactRefreshCurrentExports$);
}
//# sourceURL=[module]
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/components/ChannelsList/ChannelsListBase.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://anychan/./src/components/ChannelsList/ChannelsListBase.js?b2a3"],"sourcesContent":["import * as __react_refresh_runtime__ from 'C:/dev/anychan/node_modules/react-refresh/runtime.js';\n__webpack_require__.$Refresh$.runtime = __react_refresh_runtime__;\n\nfunction _array_like_to_array(arr, len) {\n    if (len == null || len > arr.length) len = arr.length;\n    for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n    return arr2;\n}\nfunction _array_with_holes(arr) {\n    if (Array.isArray(arr)) return arr;\n}\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n    try {\n        var info = gen[key](arg);\n        var value = info.value;\n    } catch (error) {\n        reject(error);\n        return;\n    }\n    if (info.done) {\n        resolve(value);\n    } else {\n        Promise.resolve(value).then(_next, _throw);\n    }\n}\nfunction _async_to_generator(fn) {\n    return function() {\n        var self = this, args = arguments;\n        return new Promise(function(resolve, reject) {\n            var gen = fn.apply(self, args);\n            function _next(value) {\n                asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n            }\n            function _throw(err) {\n                asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n            }\n            _next(undefined);\n        });\n    };\n}\nfunction _iterable_to_array_limit(arr, i) {\n    var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n    if (_i == null) return;\n    var _arr = [];\n    var _n = true;\n    var _d = false;\n    var _s, _e;\n    try {\n        for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n            _arr.push(_s.value);\n            if (i && _arr.length === i) break;\n        }\n    } catch (err) {\n        _d = true;\n        _e = err;\n    } finally{\n        try {\n            if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n        } finally{\n            if (_d) throw _e;\n        }\n    }\n    return _arr;\n}\nfunction _non_iterable_rest() {\n    throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _sliced_to_array(arr, i) {\n    return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n    if (!o) return;\n    if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n    var n = Object.prototype.toString.call(o).slice(8, -1);\n    if (n === \"Object\" && o.constructor) n = o.constructor.name;\n    if (n === \"Map\" || n === \"Set\") return Array.from(n);\n    if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\nfunction _ts_generator(thisArg, body) {\n    var f, y, t, g, _ = {\n        label: 0,\n        sent: function() {\n            if (t[0] & 1) throw t[1];\n            return t[1];\n        },\n        trys: [],\n        ops: []\n    };\n    return g = {\n        next: verb(0),\n        \"throw\": verb(1),\n        \"return\": verb(2)\n    }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() {\n        return this;\n    }), g;\n    function verb(n) {\n        return function(v) {\n            return step([\n                n,\n                v\n            ]);\n        };\n    }\n    function step(op) {\n        if (f) throw new TypeError(\"Generator is already executing.\");\n        while(_)try {\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n            if (y = 0, t) op = [\n                op[0] & 2,\n                t.value\n            ];\n            switch(op[0]){\n                case 0:\n                case 1:\n                    t = op;\n                    break;\n                case 4:\n                    _.label++;\n                    return {\n                        value: op[1],\n                        done: false\n                    };\n                case 5:\n                    _.label++;\n                    y = op[1];\n                    op = [\n                        0\n                    ];\n                    continue;\n                case 7:\n                    op = _.ops.pop();\n                    _.trys.pop();\n                    continue;\n                default:\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n                        _ = 0;\n                        continue;\n                    }\n                    if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n                        _.label = op[1];\n                        break;\n                    }\n                    if (op[0] === 6 && _.label < t[1]) {\n                        _.label = t[1];\n                        t = op;\n                        break;\n                    }\n                    if (t && _.label < t[2]) {\n                        _.label = t[2];\n                        _.ops.push(op);\n                        break;\n                    }\n                    if (t[2]) _.ops.pop();\n                    _.trys.pop();\n                    continue;\n            }\n            op = body.call(thisArg, _);\n        } catch (e) {\n            op = [\n                6,\n                e\n            ];\n            y = 0;\n        } finally{\n            f = t = 0;\n        }\n        if (op[0] & 5) throw op[1];\n        return {\n            value: op[0] ? op[1] : void 0,\n            done: true\n        };\n    }\n}\nimport \"core-js/modules/es.array.includes.js\";\nimport \"core-js/modules/es.string.includes.js\";\nimport \"core-js/modules/es.array.reduce.js\";\nimport \"core-js/modules/es.object.to-string.js\";\nimport \"core-js/modules/es.array.concat.js\";\nimport \"core-js/modules/es.array.map.js\";\nimport \"core-js/modules/es.array.filter.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useState, useCallback } from \"react\";\nimport PropTypes from \"prop-types\";\nimport { Link } from \"react-pages\";\nimport { useDispatch } from \"react-redux\";\nimport { Button } from \"react-responsive-ui\";\nimport classNames from \"classnames\";\nimport { saveChannelsView } from \"../../redux/settings.js\";\nimport { getChannels } from \"../../redux/data.js\";\nimport useMessages from \"../../hooks/useMessages.js\";\nimport useSettings from \"../../hooks/useSettings.js\";\nimport useDataSource from \"../../hooks/useDataSource.js\";\nimport useMultiDataSource from \"../../hooks/useMultiDataSource.js\";\nimport ChannelsListSearch from \"./ChannelsListSearch.js\";\nimport ChannelsListViewSwitcher from \"./ChannelsListViewSwitcher.js\";\nimport \"./ChannelsListBase.css\";\n// `<Channels/>` are used in `pages/Channels.js`.\nexport default function ChannelsListBase(param) {\n    var views = param.views, channels = param.channels, channelsByPopularity = param.channelsByPopularity, channelsByCategory = param.channelsByCategory, channelsViewSetting = param.channelsView, shouldSaveChannelsView = param.shouldSaveChannelsView, showAllChannels = param.showAllChannels, showAllChannelsLink = param.showAllChannelsLink, ListComponent = param.listComponent, selectedChannel = param.selectedChannel, highlightSelectedChannel = param.highlightSelectedChannel, hasMoreChannels = param.hasMoreChannels, className = param.className;\n    var dispatch = useDispatch();\n    var messages = useMessages();\n    var userSettings = useSettings();\n    var dataSource = useDataSource();\n    var multiDataSource = useMultiDataSource();\n    var _useState = _sliced_to_array(useState(), 2), filteredChannels = _useState[0], setFilteredChannels = _useState[1];\n    var _useState1 = _sliced_to_array(useState(), 2), view = _useState1[0], setView = _useState1[1];\n    var defaultChannelsView = getChannelsView(channelsViewSetting, {\n        canViewByCategory: Boolean(channelsByCategory) && views && views.includes(\"by-category\"),\n        canViewByPopularity: Boolean(channelsByPopularity)\n    });\n    var channelsView = view || defaultChannelsView;\n    var onViewChange = useCallback(function(view) {\n        setView(view);\n        if (shouldSaveChannelsView) {\n            dispatch(saveChannelsView({\n                channelsView: view,\n                userSettings: userSettings\n            }));\n        }\n    }, [\n        dispatch\n    ]);\n    var isChannelSelected = useCallback(function(channel) {\n        return highlightSelectedChannel && selectedChannel && channel.id === selectedChannel.id;\n    }, [\n        highlightSelectedChannel,\n        selectedChannel\n    ]);\n    var getChannelsListItems = useCallback(function() {\n        switch(channelsView){\n            case \"by-category\":\n                return channelsByCategory.reduce(function(all, category, i) {\n                    return all.concat([\n                        {\n                            key: category.category || \"—\",\n                            category: category.category,\n                            first: i === 0\n                        }\n                    ]).concat(category.channels.map(function(channel) {\n                        return {\n                            key: channel.id,\n                            channel: channel,\n                            selected: isChannelSelected(channel)\n                        };\n                    }));\n                }, []);\n            case \"list\":\n                return (filteredChannels || channelsByPopularity || channels).filter(function(channel) {\n                    return showAllChannels || !channel.isHidden;\n                }).map(function(channel) {\n                    return {\n                        key: channel.id,\n                        channel: channel,\n                        selected: isChannelSelected(channel)\n                    };\n                });\n            default:\n                // Unsupported `channelsView`.\n                return [];\n        }\n    }, [\n        channelsView,\n        channels,\n        channelsByPopularity,\n        channelsByCategory,\n        filteredChannels,\n        isChannelSelected,\n        showAllChannels\n    ]);\n    var loadChannelsList = useCallback(/*#__PURE__*/ _async_to_generator(function() {\n        return _ts_generator(this, function(_state) {\n            switch(_state.label){\n                case 0:\n                    return [\n                        4,\n                        dispatch(getChannels({\n                            userSettings: userSettings,\n                            dataSource: dataSource,\n                            multiDataSource: multiDataSource,\n                            messages: messages\n                        }))\n                    ];\n                case 1:\n                    _state.sent();\n                    return [\n                        2\n                    ];\n            }\n        });\n    }), [\n        dispatch,\n        userSettings,\n        dataSource,\n        multiDataSource,\n        messages\n    ]);\n    if (!channels) {\n        return /*#__PURE__*/ _jsxs(\"p\", {\n            className: \"Channels-error\",\n            children: [\n                /*#__PURE__*/ _jsx(\"span\", {\n                    className: \"Channels-errorText\",\n                    children: messages.boards.error\n                }),\n                /*#__PURE__*/ _jsx(\"br\", {}),\n                /*#__PURE__*/ _jsx(Button, {\n                    className: \"Channels-errorRetry\",\n                    onClick: loadChannelsList,\n                    children: messages.actions.retry\n                })\n            ]\n        });\n    }\n    return /*#__PURE__*/ _jsxs(\"nav\", {\n        className: \"Channels\",\n        children: [\n            views && views.includes(\"list\") && channelsByPopularity && channelsByCategory && views.includes(\"by-category\") && /*#__PURE__*/ _jsx(ChannelsListViewSwitcher, {\n                view: channelsView,\n                onViewChange: onViewChange\n            }),\n            showAllChannels && channelsView === \"list\" && /*#__PURE__*/ _jsx(ChannelsListSearch, {\n                channels: channels || channelsByPopularity,\n                setSearchResults: setFilteredChannels\n            }),\n            /*#__PURE__*/ _jsx(ListComponent, {\n                className: classNames(\"Channels-list\", {\n                    // 'Channels-list--list': channelsView === 'list',\n                    \"Channels-list--by-category\": channelsView === \"by-category\"\n                }),\n                children: getChannelsListItems()\n            }),\n            !showAllChannels && showAllChannelsLink && (hasMoreChannels || dataSource.contentCategoryUnspecified) && /*#__PURE__*/ _jsx(\"div\", {\n                className: \"Channels-showAllWrapper\",\n                children: /*#__PURE__*/ _jsx(Link, {\n                    to: \"/channels\",\n                    className: \"Channels-showAll\",\n                    children: messages.boards.showAll\n                })\n            })\n        ]\n    });\n}\nexport var channelShape = {\n    id: PropTypes.string.isRequired,\n    title: PropTypes.string.isRequired,\n    description: PropTypes.string,\n    commentsPerHour: PropTypes.number\n};\nChannelsListBase.propTypes = {\n    views: PropTypes.arrayOf(PropTypes.oneOf([\n        \"list\",\n        \"by-category\"\n    ])),\n    channels: PropTypes.arrayOf(PropTypes.shape(channelShape)),\n    channelsByPopularity: PropTypes.arrayOf(PropTypes.shape(channelShape)),\n    channelsByCategory: PropTypes.arrayOf(PropTypes.shape({\n        category: PropTypes.string.isRequired,\n        channels: PropTypes.arrayOf(PropTypes.shape(channelShape)).isRequired\n    })),\n    channelsView: PropTypes.string,\n    shouldSaveChannelsView: PropTypes.bool,\n    showAllChannels: PropTypes.bool,\n    showAllChannelsLink: PropTypes.bool,\n    selectedChannel: PropTypes.shape(channelShape),\n    highlightSelectedChannel: PropTypes.bool,\n    // isChannelOrThreadLocation: PropTypes.bool,\n    hasMoreChannels: PropTypes.bool,\n    // dispatch: PropTypes.func,\n    listComponent: PropTypes.elementType.isRequired,\n    className: PropTypes.string\n};\nfunction getChannelsView(channelsView, param) {\n    var canViewByCategory = param.canViewByCategory, canViewByPopularity = param.canViewByPopularity;\n    switch(channelsView){\n        case \"by-category\":\n            if (canViewByCategory) {\n                return channelsView;\n            }\n        case \"list\":\n            return channelsView;\n    }\n    if (canViewByPopularity) {\n        return \"list\";\n    }\n    if (canViewByCategory) {\n        return \"by-category\";\n    }\n    return \"list\";\n}\n\n\nconst $ReactRefreshModuleId$ = __webpack_require__.$Refresh$.moduleId;\nconst $ReactRefreshCurrentExports$ = __react_refresh_utils__.getModuleExports(\n\t$ReactRefreshModuleId$\n);\n\nfunction $ReactRefreshModuleRuntime$(exports) {\n\tif (import.meta.webpackHot) {\n\t\tlet errorOverlay;\n\t\tif (typeof __react_refresh_error_overlay__ !== 'undefined') {\n\t\t\terrorOverlay = __react_refresh_error_overlay__;\n\t\t}\n\t\tlet testMode;\n\t\tif (typeof __react_refresh_test__ !== 'undefined') {\n\t\t\ttestMode = __react_refresh_test__;\n\t\t}\n\t\treturn __react_refresh_utils__.executeRuntime(\n\t\t\texports,\n\t\t\t$ReactRefreshModuleId$,\n\t\t\timport.meta.webpackHot,\n\t\t\terrorOverlay,\n\t\t\ttestMode\n\t\t);\n\t}\n}\n\nif (typeof Promise !== 'undefined' && $ReactRefreshCurrentExports$ instanceof Promise) {\n\t$ReactRefreshCurrentExports$.then($ReactRefreshModuleRuntime$);\n} else {\n\t$ReactRefreshModuleRuntime$($ReactRefreshCurrentExports$);\n}"],"names":[],"sourceRoot":""}
//# sourceURL=webpack-internal:///./src/components/ChannelsList/ChannelsListBase.js |
@kdy1 FYI: the issue you've linked doesn't seem to describe this case. In any case, here're the final thoughts: The reason seems to be that before |
This closed issue has been automatically locked because it had no new activity for a month. If you are running into a similar issue, please create a new issue with the steps to reproduce. Thank you. |
Describe the bug
Is reproduced in
@swc/core@^1.3.105
and1.4.x
.Is not reproduced in
@swc/[email protected]
.The issue seems to be used by such code:
Source code:
https://github.com/catamphetamine/anychan/blob/662d897b50ac4905ea6dc68b7c3b6b02af50a2cf/src/components/ChannelsList/ChannelsListBase.js#L164
Compiled:
Input code
https://github.com/catamphetamine/anychan/blob/662d897b50ac4905ea6dc68b7c3b6b02af50a2cf/src/components/ChannelsList/ChannelsListBase.js#L164
Config
Playground link (or link to the minimal reproduction)
https://github.com/catamphetamine/anychan/blob/662d897b50ac4905ea6dc68b7c3b6b02af50a2cf/src/components/ChannelsList/ChannelsListBase.js#L164
SWC Info output
No response
Expected behavior
No error
Actual behavior
Error
Version
1.3.105
Additional context
I didn't add a "playground" because the issue was reproduced in a real app. See for yourself if you'd like to investigate it or not. I'm fine with not updating to
1.4.x
if the bug is not fixed there.The text was updated successfully, but these errors were encountered: