+ var link = document.createElement('link'); - link.href = "".concat(this.assetPrefix, "/_next/static/").concat(encodeURIComponent(this.buildId), "/pages").concat(scriptRoute); + link.href = "".concat(_this7.assetPrefix, "/_next/static/").concat(encodeURIComponent(_this7.buildId), "/pages").concat(scriptRoute); - if (! const relativePagePath = `${normalizedPagePath}.${extension}`; const pagePath = path_1.join(rootDir, relativePagePath); if (await is_writeable_1.isWriteable(pagePath)) {. + return _this7.loadPage(route).catch(function () {}); + return new _promise.default(function (resolve) {, + window.addEventListener('load', function () {, + _this7.loadPage(route).then(function () {, - this.prefetchCache.add(scriptRoute); // Inspired by quicklink, license: https://github.com/GoogleChromeLabs/quicklink/blob/master/LICENSE, - // Don't prefetch if the user is on 2G / Don't prefetch if Save-Data is enabled. - } : {}), { 'process.env.__NEXT_EXPORT_TRAILING_SLASH': JSON.stringify(config.experimental.exportTrailingSlash) })). + route = _this7.normalizeRoute(route); + var scriptRoute = route === '/' ? + const chunkModules = new Map(); + const queue = new Set(chunk.groupsIterable); + const chunksProcessed = new Set(); + const involvedChunks = new Set(); + for (const chunkGroup of queue) {, + for (const chunk of chunkGroup.chunks) {. - _context3.t0 = _context3.sent; - return doRender((0, _assign.default)({}, props, {. + ext)); + let pagePath = await find_page_file_1.findPageFile(pagesDir, normalizedPagePath, pageExtensions); // Default the /_error route to the Next.js provided default page, if (page === '/_error' && pagePath === null) {. + throw new Error('arguments can only be string or number'); + throw new Error('key not provided to createHook options. ['.js', '.mjs', '.jsx', '.json', '.wasm'] : ['.mjs', '.js', '.jsx', '.json', '.wasm'], nodePathList // Support for NODE_PATH environment variable. + const { request } = chunkGroupOrigin; + chunkGroup.chunks.forEach(chunk => {, + chunk.files.forEach(file => {, if (!file.match(/\.js$/) || !file.match(/^static\/chunks\//)) {. - return loadable_1.default.preloadReady(dynamicIds || []); exports.router = router_1.createRouter(page, query, asPath, {, - exports.router.subscribe(function (_ref5) {. - // While we were updating, there was a new update! -_Note: The contents of `` get cleared upon unmounting the component, so make sure each page completely defines what it needs in ``, without making assumptions about what other pages added_, +_Note: The contents of `` get cleared upon unmounting the component, so make sure each page completely defines what it needs in ``, without making assumptions about what other pages added._, _Note: `` and `<meta>` elements need to be contained as **direct** children of the `<Head>` element, or wrapped into maximum one level of `<React.Fragment>`, otherwise the metatags won't be correctly picked up on clientside navigation._, - [@zeit/next-preact](https://github.com/zeit/next-plugins/tree/master/packages/next-preact), - [@zeit/next-typescript](https://github.com/zeit/next-plugins/tree/master/packages/next-typescript), -_Warning: The `webpack` function is executed twice, once for the server and once for the client. 'Creating a development build '. var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault"); -var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator")); -var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator")); +// Attempt to update code on the fly, fall back to a hard reload. - src: "".concat(assetPrefix, "/_next/static/").concat(buildId, "/pages").concat(getPagePathname(page)).concat(_devOnlyInvalidateCacheQueryString). - const sharedRuntime = config.experimental.sharedRuntime && target === 'serverless'; - devtool: dev ? - }, props); // lastAppProps has to be set before ReactDom.render to account for ReactDom throwing an error. + console.warn('Error while applying updates, reloading page', err); + console.warn('Had runtime error previously, reloading page'); + if (typeof onHotUpdateSuccess === 'function') {. 'cheap-module-source-map' : false. ['main', 'module'] : ['browser', 'module', 'main']. + request = path_1.default.relative(dir, request); + if (path_1.default.isAbsolute(context)) {. + await this._restoreSema.acquire(); + const manifestPath = path_1.default.join(this.shuttleDirectory, constants_1.CHUNK_GRAPH_MANIFEST); + const manifest = require(manifestPath); + const { pages, pageChunks, hashes } = manifest; + if (! + !process.env.__NEXT_BUILDER_EXPERIMENTAL_PAGE); + const selectivePageBuilding = Boolean(isFlyingShuttle || process.env.__NEXT_BUILDER_EXPERIMENTAL_PAGE); + if (selectivePageBuilding && config.target !== 'serverless') {. - return SingletonRouter.router[field]; coreMethodFields.forEach(function (field) {, + // We don't really know the types here, so we add them later instead. ampPath : "".concat(asPath).concat(asPath.includes('?') + exclude: /\.min\.(js|mjs|jsx)$/. + test: /\.(js|mjs|jsx)$/. "/index. We also automatically insert the `<link rel="amphtml" href="/page.amp" />` and `<link rel="canonical" href="/" />` tags for you. https://err.sh/zeit/next.js/env-key-not-allowed`); return Object.assign({}, acc, { [`process.env.${key}`]: JSON.stringify(config.env[key]) }); - }, {})), { 'process.crossOrigin': JSON.stringify(config.crossOrigin), 'process.browser': JSON.stringify(!isServer) }, (dev && !isServer ? +const chunk_graph_plugin_1 = require("./webpack/plugins/chunk-graph-plugin"); +function getBaseWebpackConfig(dir, { dev = false, debug = false, isServer = false, buildId, config, target = 'server', entrypoints, selectivePageBuilding = false, selectivePageBuildingCacheIdentifier = '' }) {, - options: { isServer, cwd: dir }, + options: { isServer, cwd: dir, asyncToPromises: config.experimental.asyncToPromises }, // Disable .mjs for node_modules bundling. + const u = unchangedPages.length; + const c = pageNames.length - u; + Log.info(`found ${c} changed and ${u} unchanged page${u > 1 ? + manifest.chunks[chunk.name] = files; + const getLambdaChunk = (name) => name.includes(this.buildId), + .replace(new RegExp(`${this.buildId}[\\/\\\\]`), 'client/'), + .replace(/[. + let mod = require(serverPage); + mod = mod.default || mod; + if (mod && mod.__nextAmpOnly) {. - return _tryApplyUpdates.apply(this, arguments); - _tryApplyUpdates = (0, _asyncToGenerator2.default)(, - _regenerator.default.mark(function _callee(onHotUpdateSuccess) {. - compress: false. badProp += " ".concat(prop, "=\"").concat(props[prop], "\""); console.warn("Found conflicting amp tag \"".concat(child.type, "\" with conflicting prop ").concat(badProp, ". + const json = JSON.stringify(manifest, null, 2) + os_1.EOL; + compilation.assets[this.filename] = {. (await is_writeable_1.isWriteable(dir))) {. + // HotModuleReplacementPlugin is not in Webpack configuration. +var mitt_1 = __importDefault(require("next-server/dist/lib/mitt")); +var unfetch_1 = __importDefault(require("unfetch")); // smaller version of https://gist.github.com/igrigorik/a02f2359f3bc50ca7a9c. (await fsExists(nextManifestPath))) {. + id = path_1.default.resolve(dir, id); + .reduce((acc, val) => val.modules, + ? You signed in with another tab or window. - }); // In development runtime errors are caught by react-error-overlay. + isValidElementType = _require.isValidElementType; - _renderError = (0, _asyncToGenerator2.default)(, - _regenerator.default.mark(function _callee3(props) {, - return _regenerator.default.wrap(function _callee3$(_context3) {, - switch (_context3.prev = _context3.next) {. {, + minimizer: ! + !isServer && selectivePageBuilding && new shared_runtime_plugin_1.SharedRuntimePlugin(), !dev && new webpack_1.default.IgnorePlugin({. Cannot find module 'next/dist/next-server/lib/utils' or its corresponding type declarations. isServer && new nextjs_ssr_import_1.default(). - ErrorComponent: exports.ErrorComponent. + // Maybe we want to do something. - SingletonRouter[eventField].apply(SingletonRouter, arguments); + singletonRouter[eventField].apply(singletonRouter, arguments); - console.error("Error when running the Router event: ".concat(eventField)); + // tslint:disable-next-line:no-console, + console.error("Error when running the Router event: ".concat(eventField)); // tslint:disable-next-line:no-console. + ready: chalk_1.default `[ {green ready} ]`. - { event: 'SIGQUIT', handler: () => exit('SIGQUIT') }. + pageChunks[page]. throw require_1.pageNotFoundError(normalizedPagePath); - let pagePath = await find_page_file_1.findPageFile(pagesDir, normalizedPagePath, pageExtensions, amp, ampEnabled); - const isAmp = pagePath && pageExtensions.some(ext => pagePath.endsWith('amp.' additionalClientEntrypoints[constants_1.CLIENT_STATIC_FILES_RUNTIME_AMP] = `.${path_1.sep}` + path_1.relative(this.dir, path_1.join(constants_2.NEXT_PROJECT_ROOT_DIST_CLIENT, 'amp-dev')); webpack_config_1.default(this.dir, { dev: true, isServer: false, config: this.config, buildId: this.buildId, entrypoints: Object.assign({}, entrypoints.client, additionalClientEntrypoints) }), webpack_config_1.default(this.dir, { dev: true, isServer: true, config: this.config, buildId: this.buildId, entrypoints: entrypoints.server }). + return specifier.isImportSpecifier() && specifier.node.imported.name === 'createHook'; + if (!createHookSpecifier). const worker_farm_1 = __importDefault(require("worker-farm")); -const find_cache_dir_1 = __importDefault(require("find-cache-dir")); const serialize_javascript_1 = __importDefault(require("serialize-javascript")); const worker = require.resolve('./worker'); const writeFileP = util_1.promisify(fs_1.writeFile); const readFileP = util_1.promisify(fs_1.readFile); - this.cacheDir = find_cache_dir_1.default({ name: 'next-minifier', create: true }); + mkdirp_1.default.sync((this.cacheDir = path_1.join(distDir, 'cache', 'next-minifier'))); // In some cases cpus() returns undefined, // https://github.com/nodejs/node/issues/19022. amphtml = _this$context$_docume4.amphtml. "/_next/static/client/pages".concat(getPageFile(page, buildId)) : "/_next/static/".concat(buildId, "/pages").concat(getPageFile(page))) + _devOnlyInvalidateCacheQueryString, crossOrigin: this.props.crossOrigin || process.crossOrigin. `res.statusCode = 404` : ''}, - const result = await renderToHTML(req, res, "${page}", parsedUrl.query, Object.assign({}, options, {, + const result = await renderToHTML(req, res, "${page}", parsedUrl.query, Object.assign(. + return preset[0] === require('@babel/preset-env').default; + babelPresetEnv[1].exclude = (options.presets[0][1].exclude || []).concat([. + const ampHtmlFilename = `${ampPath}${path_1.sep}index.html`; + const ampBaseDir = path_1.join(outDir, path_1.dirname(ampHtmlFilename)); + const ampHtmlFilepath = path_1.join(outDir, ampHtmlFilename); + await accessP(ampHtmlFilepath); + // make sure it doesn't exist from manual mapping. + .filter(e => this._filterAmpDevelopmentScript(html, e)), result.errors.filter(e => e.severity !== 'ERROR')); return constants_1.PHASE_DEVELOPMENT_SERVER; // In dev mode we use on demand entries to compile the page before rendering. -// and they are still handle via the main render method. +Pages are also validated during `next export` and any warnings / errors will be printed to the terminal. + include: [path_1.default.join(dir, 'data')], + use: 'next-data-loader'. + src: assetPrefix + (dynamicBuildId ? const buildIdPath = path_1.join(distDir, constants_1.BUILD_ID_FILE); await writeFile(buildIdPath, buildId, 'utf8'); + const headBuildIdPath = path_1.join(distDir, constants_1.HEAD_BUILD_ID_FILE); + await writeFile(headBuildIdPath, buildId, 'utf8'); - '--experimental-page': [String]. + exports.emitter.emit('before-reactdom-render', {. _temp4.then(_temp3) : _temp3(_temp4)); +var react_1 = __importDefault(require("react")); var router_1 = __importDefault(require("next-server/dist/lib/router/router")); +var request_context_1 = require("next-server/dist/lib/request-context"); -}; // Create public properties and methods of the router in the SingletonRouter, +}; // const x = SingletonRouter as IRealRouter, +// Create public properties and methods of the router in the SingletonRouter. -// 404 and 500 errors are special kind of errors. '); // window.location.reload(); - return _context.abrupt("return"); - if (! + loader: 'next-minify-loader', + options: { terserOptions: { safari10: true, compress: true, mangle: false } }, + config.experimental.ampBindInitData && !isServer && {. + let request = m.readableIdentifierStr.replace(/ \(ignored\)$/, ''); + .match(new RegExp(`^ignored (. ]js$/, `.${this.buildId}.js`)] = compilation.assets[name]; exports.ServerlessPlugin = ServerlessPlugin; -const imurmurhash_1 = __importDefault(require("imurmurhash")); const source_map_1 = require("source-map"); const webpack_sources_1 = require("webpack-sources"); const RequestShortener_1 = __importDefault(require("webpack/lib/RequestShortener")); - const { terserOptions = {}, warningsFilter = () => true, sourceMap = false, cache = false, cpus, } = options; + const { terserOptions = {}, warningsFilter = () => true, sourceMap = false, cache = false, cpus, distDir, } = options; - terserOptions: Object.assign({ output: {. + const filename = this.resourcePath; const options = Object.assign({}, cfg.options); for (const file of [cfg.babelrc, cfg.config]) {. Anything in next/dist should not be imported. + error: chalk_1.default `[ {red error} ]`. + this.callback(new Error(`Error from Terser: ${error.message}`)); const querystring_1 = require("querystring"); const nextServerlessLoader = function () {. + pageExtensions: config.pageExtensions, + return Promise.reject(new Error(`Failed to locate page file: ${page}. const { mainTemplate, chunkTemplate } = compilation; // Regenerate `contenthash` for minified assets, for (const template of [mainTemplate, chunkTemplate]) {, - template.hooks.hashForChunk.tap(plugin, (hash) => {, + template.hooks.hashForChunk.tap(plugin, hash => {, // Has to be updated when options change too. '/index.js' : "".concat(route, ".js"); - if (! + return _promise.default.resolve(pageLoader.loadPage('/_error')).then(function (_pageLoader$loadPage3) {, + return _promise.default.resolve(doRender((0, _assign.default)({}, props, {. + generateEtags: config.generateEtags. 'next/app', 'next/document', 'next/link', 'next/error', // When the serverless target is used all node_modules will be compiled into the output bundles, // So that the serverless bundles have 0 runtime dependencies, + 'amp-toolbox-optimizer' // except this one. + }, react_1.default.createElement(App, (0, _assign.default)({}, appProps))))))), appContainer); + exports.emitter.emit('after-reactdom-render', {, + if (!props && Component && Component !== exports.ErrorComponent && lastAppProps.Component === exports.ErrorComponent) {. - return _getInitialProps.apply(this, arguments); var _now = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/date/now")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck")); -var react_1 = __importStar(require("react")); var prop_types_1 = __importDefault(require("prop-types")); var utils_1 = require("next-server/dist/server/utils"); var htmlescape_1 = require("../server/htmlescape"); var constants_1 = require("next-server/constants"); + return ampPath ? mod : {, +var doRender = function doRender(_ref5) {. Do it again. +Both of these page modes provide a consistently fast experience for users accessing pages through search engines. + console.log(` \x1b[90m${corner}\x1b[39m ${item}`); + return arr.reduce((acc, val) => acc.concat(val), []); +function getPossibleFiles(pageExtensions, pages) {, + const res = pages.map(page => pageExtensions, + .concat(pageExtensions.map(e => `${path_1.default.join(page, 'index')}.${e}`)), +async function getFileForPage({ page, pagesDirectory, pageExtensions, }) {, + const theFile = getPossibleFiles(pageExtensions, [. The duplicate babel messages have been fixed already on next@canary, will be out on the stable channel soon . '/index' : page; + if (constants_1.BLOCKED_PAGES.includes(page)) {. 'commonjs2' : 'var'. + throw new Error('Cannot handle a MultiModule with moduleless dependencies'); + throw new Error('Cannot handle a MultiModule dependency without a module id'); + const identifier = ids.sort().join('::'); + console.warn(`> module identifier: MultiModule ${m.identifier()} => ${identifier}`); compiler.hooks.compilation.tap('AllModulesIdentifiedPlugin', compilation => {, compilation.hooks.beforeModuleIds.tap('AllModulesIdentifiedPlugin', modules => {, - if (m.id != null || !m.identifier) {. Multiple configurations can be combined together with function composition. - readline_1.default.cursorTo(process.stdout, 0, 0); - readline_1.default.clearScreenDown(process.stdout); - console.log(chalk_1.default.cyan('Starting the development server ')); - console.log(` > Waiting on ${state.appUrl}`); + Log.wait('starting the development server '); + Log.info(`waiting on ${state.appUrl} `); - console.log(chalk_1.default.red('Failed to compile. + selectivePageBuildingCacheIdentifier += await fsReadFile(packageLock, 'utf8'); + selectivePageBuildingCacheIdentifier += JSON.stringify(require(pkgPath)); + .update(selectivePageBuildingCacheIdentifier). options.presets = [options.presets, presetItem]; + if (isServer && source.indexOf('next/data') !== -1) {. ").concat(buildId, ".js") : "".concat(page, ".js"); find_page_file_1.findPageFile(pagesDir, '/_document', this.config.pageExtensions). We can't recover from this yet.`)); + const pageSet = new Set(pagePaths); + for (const unchangedPage of unchangedPages) {. + .map(f => fsExists(f))); + if (!filesExists.every(Boolean)) {. + const prop = (match.split(']').shift() || '').substr(1); + console.log(`AMP bind syntax [${prop}]='' is not supported in JSX, use 'data-amp-bind-${prop}' instead. +const { CUSTOM_KEY, CUSTOM_SECRET } = process.env; +AuthMethod({ key: CUSTOM_KEY, secret: CUSTOM_SECRET }); +AuthMethod({ key: process.env.CUSTOM_KEY, secret: process.env.CUSTOM_SECRET }); -> :warning: Note that this option is not available when using `target: 'serverless'`, +> **Warning:** Note that this option is not available when using `target: 'serverless'`. + : 'Creating an optimized production build '); const config = next_config_1.default(constants_1.PHASE_PRODUCTION_BUILD, dir, conf); - const buildId = await generate_build_id_1.generateBuildId(config.generateBuildId, index_js_1.default); - const distDir = path_1.join(dir, config.distDir); - const pagesDir = path_1.join(dir, 'pages'); + : await generate_build_id_1.generateBuildId(config.generateBuildId, index_js_1.default); + const distDir = path_1.default.join(dir, config.distDir); + const pagesDir = path_1.default.join(dir, 'pages'); + const isFlyingShuttle = Boolean(config.experimental.flyingShuttle &&. + pageChunks: Object.assign({}, this._recalledManifest.pageChunks, nextManifest.pageChunks). + ErrorComponent: exports.ErrorComponent. + const source = path.node.source.value; + if (source !== 'next/data'), + const createHookSpecifier = path.get('specifiers').find(specifier => {. +Hybrid AMP (`pages/about.js`) would output: +- `out/about/index.html` - with client-side React runtime. + manifest[request] = []; - if (manifest[currentModule.rawRequest].some(item => item.file === file)) {, + if (manifest[request].some(item => item.file === file)) {, - manifest[currentModule.rawRequest].push({, + manifest[request].push({, + constructor(buildId, { isServer = false } = {}) {. path_1.relative(pagesDir, page) : page)); + if (process.env.__NEXT_BUILDER_EXPERIMENTAL_PAGE) {. + return _props$props ? const { serverRuntimeConfig, publicRuntimeConfig } = nextConfig; const mkdirp_1 = __importDefault(require("mkdirp")); const render_1 = require("next-server/dist/server/render"); const async_sema_1 = __importDefault(require("async-sema")); const load_components_1 = require("next-server/dist/server/load-components"); const envConfig = require('next-server/config'); const mkdirp = util_1.promisify(mkdirp_1.default); +const writeFileP = util_1.promisify(fs_1.writeFile); +const accessP = util_1.promisify(fs_1.access); + const ampPath = `${path === '/' ? + identifier = getRawModuleIdentifier(m, this.dir); + else if (m.constructor &&, + m.constructor.name === 'MultiModule') {. [constants_2.PAGES_DIR_ALIAS]: path_1.default.join(dir, 'pages'), - [constants_2.DOT_NEXT_ALIAS]: distDir. :${pageExtensions.join('|')})$`)); - .sort((a, b) => (a > b ? - route = this.normalizeRoute(route); + this.promisedBuildId = new _promise.default(function (resolve) {, + unfetch_1.default("".concat(_this2.assetPrefix, "/_next/static/HEAD_BUILD_ID")).then(function (res) {. + const serverPage = path_1.default.join(distDir, config.target === 'serverless' ? + throw new Error(`Cannot use ${isFlyingShuttle ? +const loader_utils_1 = __importDefault(require("loader-utils")); +const minify_1 = __importDefault(require("../plugins/terser-webpack-plugin/src/minify")); +const nextMiniferLoader = function (source) {. ]js$/, `.${this.buildId}.js`). + return _promise.default.resolve(_temp7 && _temp7.then ? - }, react_1.default.createElement(App, (0, _assign.default)({}, appProps)))), appContainer); - exports.emitter.emit('after-reactdom-render', {. }, on_demand_entries_utils_1.currentPage); - return _ref2.apply(this, arguments); var _set = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/set")); -var mitt_1 = __importDefault(require("next-server/dist/lib/mitt")); // smaller version of https://gist.github.com/igrigorik/a02f2359f3bc50ca7a9c. + devtool: (dev || debug) ? *\]=/); + for (const match of matches) {. ]/g; + throw new TypeError('Expected a string'); + return str.replace(matchOperatorsRe, '\\$&'); +function getRawModuleIdentifier(m, dir) {. + let callExpression = refPath.parentPath; + if (!callExpression.isCallExpression()). + var err = new Error('Failed to fetch HEAD buildId'); + _this2.buildId = buildId.trim(); + // When this fails it's not a _huge_ deal, preload wont work and page, + // navigation will 404, triggering a SSR refresh. + /* dynamicBuildId */ selectivePageBuilding, config); + selectivePageBuildingCacheIdentifier. + if (process.env.NODE_ENV === 'development') {, + renderReactElement(react_1.default.createElement(react_1.Suspense, {, + fallback: react_1.default.createElement("div", null, "Loading"), + }, react_1.default.createElement(router_context_1.RouterContext.Provider, {, + value: router_1.makePublicRouterInstance(exports.router), + }, react_1.default.createElement(data_manager_context_1.DataManagerContext.Provider, {, + }, react_1.default.createElement(head_manager_context_1.HeadManagerContext.Provider, {. + handleApplyUpdates(null, updatedModules); -} // Attempt to update code on the fly, fall back to a hard reload. undefined : target !== 'serverless' ? + this.filename = filename || 'chunk-graph-manifest.json'; + this.selectivePageBuildingCacheIdentifier =. - // HotModuleReplacementPlugin is not in Webpack configuration. const next_server_1 = __importDefault(require("next-server/dist/server/next-server")); const error_debug_1 = __importDefault(require("./error-debug")); const amphtml_validator_1 = __importDefault(require("amphtml-validator")); const index_1 = require("../build/output/index"); +const Log = __importStar(require("../build/output/log")); class DevServer extends next_server_1.default {, + this.renderOpts.ampValidator = (html, pathname) => {, + return amphtml_validator_1.default.getInstance().then(validator => {. + return _tryApplyUpdates.apply(this, arguments); + tryApplyUpdates.toString = function () {. Errors and warnings will appear in the terminal where you started Next.js. + const ampHtml = await render_1.renderToHTML(req, res, page, Object.assign({}, query, { amp: 1 }), curRenderOpts); + await validateAmp(ampHtml, page + '?amp=1'); + await mkdirp(ampBaseDir); + await writeFileP(ampHtmlFilepath, ampHtml, 'utf8'); - await new Promise((resolve, reject) => fs_1.writeFile(htmlFilepath, html, 'utf8', err => (err ? const { name, absolutePagePath } = entries[page]; const pageExists = await is_writeable_1.isWriteable(absolutePagePath); - console.warn('Page was removed', page); + Log.event('page was removed', page); - // Then it seems like an weird issue. !dev && new webpack_1.default.HashedModuleIdsPlugin(), // This must come after HashedModuleIdsPlugin (it sets any modules that. - exports.emitter.emit('before-reactdom-render', {. + ]).find(f => fs_1.default.existsSync(f) && fs_1.default.lstatSync(f).isFile()); + path_1.default.join(dir, p). </div> </div> <footer class="site-footer dark-skin" id="footer"> <div class="" id="site-info"> <div class="container"> <div class="tie-row"> <div class="tie-col-md-12"> <div class="copyright-text copyright-text-first"> <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/taylor-funeral-homes-obituaries.html">Taylor Funeral Homes Obituaries</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/akita-statue-for-sale-near-france.html">Akita Statue For Sale Near France</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/tiktok-anime-dance-trend.html">Tiktok Anime Dance Trend</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/artificial-plants-london.html">Artificial Plants London</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/create-your-own-community.html">Create Your Own Community</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/the-dent-schoolhouse-walkthrough.html">The Dent Schoolhouse Walkthrough</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/coach-women%27s-marley-driver-loafers-navy-blue.html">Coach Women's Marley Driver Loafers Navy Blue</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/how-to-get-epic-toppings-cookie-run-kingdom.html">How To Get Epic Toppings Cookie Run Kingdom</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/jersey-shore-italy-house-address.html">Jersey Shore Italy House Address</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/cascadian-farms-granola%2C-no-sugar-added.html">Cascadian Farms Granola, No Sugar Added</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/holy-name-hockey-springfield%2C-ma.html">Holy Name Hockey Springfield, Ma</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/lynn-michaels-punisher.html">Lynn Michaels Punisher</a>, <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/american-baby-company-crib-sheet.html">American Baby Company Crib Sheet</a>, </div> <div class="copyright-text copyright-text-second"><font size="5"> <a href="http://app.groovepay.com/profac/assets/fonts/c7criv1c/girls%27-frontline-villains.html">girls' frontline villains</a> </font></div> </div> </div> </div> </div> </footer> </div> </div> </div> </body> </html>