Giter Site home page Giter Site logo

Comments (4)

catamphetamine avatar catamphetamine commented on May 19, 2024

Additional details:

The reason seems to be that before 1.3.105 it compiled the source code as var channelShape = ... but starting with 1.3.105 it started compiling the same code as const channelShape = ... and there's a difference between const and var in that a variable declared with var can be used before it is declared whereas a variable declared with const cannot.

https://stackoverflow.com/questions/48507803/es6-modules-why-can-i-use-a-const-before-it-is-declared
https://stackoverflow.com/questions/20220862/in-javascript-can-i-use-a-variable-before-it-is-declared

Here's the whole file when it's compiled with a newer version of @swc/core which doesn't work:

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 @swc/core which doeswork:

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

from swc.

kdy1 avatar kdy1 commented on May 19, 2024

#7435

from swc.

catamphetamine avatar catamphetamine commented on May 19, 2024

@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 1.3.105 it compiled the source code as var channelShape = ... but starting with 1.3.105 it started compiling the same code as const channelShape = ... and there's a difference between const and var in that a variable declared with var can be used before it is declared whereas a variable declared with const cannot.

from swc.

catamphetamine avatar catamphetamine commented on May 19, 2024

@kdy1 Ah, ok, you meant "circular dependency". Ok, I'll see if there's one, thanks. Looks like I've potentially found one.

This man seems to have been having the same issue: #8787

from swc.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.