123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.store = void 0;
- var _unistore = _interopRequireDefault(require("next/dist/compiled/unistore"));
- var _stripAnsi = _interopRequireDefault(require("next/dist/compiled/strip-ansi"));
- var _trace = require("../../trace");
- var _swc = require("../swc");
- var Log = _interopRequireWildcard(require("./log"));
- function _interopRequireDefault(obj) {
- return obj && obj.__esModule ? obj : {
- default: obj
- };
- }
- function _getRequireWildcardCache() {
- if (typeof WeakMap !== "function") return null;
- var cache = new WeakMap();
- _getRequireWildcardCache = function() {
- return cache;
- };
- return cache;
- }
- function _interopRequireWildcard(obj) {
- if (obj && obj.__esModule) {
- return obj;
- }
- if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
- return {
- default: obj
- };
- }
- var cache = _getRequireWildcardCache();
- if (cache && cache.has(obj)) {
- return cache.get(obj);
- }
- var newObj = {};
- var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
- for(var key in obj){
- if (Object.prototype.hasOwnProperty.call(obj, key)) {
- var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
- if (desc && (desc.get || desc.set)) {
- Object.defineProperty(newObj, key, desc);
- } else {
- newObj[key] = obj[key];
- }
- }
- }
- newObj.default = obj;
- if (cache) {
- cache.set(obj, newObj);
- }
- return newObj;
- }
- const store = (0, _unistore).default({
- appUrl: null,
- bindAddr: null,
- bootstrap: true
- });
- exports.store = store;
- let lastStore = {
- appUrl: null,
- bindAddr: null,
- bootstrap: true
- };
- function hasStoreChanged(nextStore) {
- if ([
- ...new Set([
- ...Object.keys(lastStore),
- ...Object.keys(nextStore)
- ]),
- ].every((key)=>Object.is(lastStore[key], nextStore[key]))) {
- return false;
- }
- lastStore = nextStore;
- return true;
- }
- let startTime = 0;
- store.subscribe((state)=>{
- if (!hasStoreChanged(state)) {
- return;
- }
- if (state.bootstrap) {
- if (state.appUrl) {
- Log.ready(`started server on ${state.bindAddr}, url: ${state.appUrl}`);
- }
- return;
- }
- if (state.loading) {
- if (state.trigger) {
- if (state.trigger !== "initial") {
- Log.wait(`compiling ${state.trigger}...`);
- }
- } else {
- Log.wait("compiling...");
- }
- if (startTime === 0) {
- startTime = Date.now();
- }
- return;
- }
- if (state.errors) {
- Log.error(state.errors[0]);
- const cleanError = (0, _stripAnsi).default(state.errors[0]);
- if (cleanError.indexOf("SyntaxError") > -1) {
- const matches = cleanError.match(/\[.*\]=/);
- if (matches) {
- for (const match of matches){
- const prop = (match.split("]").shift() || "").slice(1);
- console.log(`AMP bind syntax [${prop}]='' is not supported in JSX, use 'data-amp-bind-${prop}' instead. https://nextjs.org/docs/messages/amp-bind-jsx-alt`);
- }
- return;
- }
- }
- startTime = 0;
- // Ensure traces are flushed after each compile in development mode
- (0, _trace).flushAllTraces();
- (0, _swc).teardownTraceSubscriber();
- (0, _swc).teardownCrashReporter();
- return;
- }
- let timeMessage = "";
- if (startTime) {
- const time = Date.now() - startTime;
- startTime = 0;
- timeMessage = time > 2000 ? ` in ${Math.round(time / 100) / 10}s` : ` in ${time} ms`;
- }
- let modulesMessage = "";
- if (state.modules) {
- modulesMessage = ` (${state.modules} modules)`;
- }
- let partialMessage = "";
- if (state.partial) {
- partialMessage = ` ${state.partial}`;
- }
- if (state.warnings) {
- Log.warn(state.warnings.join("\n\n"));
- // Ensure traces are flushed after each compile in development mode
- (0, _trace).flushAllTraces();
- (0, _swc).teardownTraceSubscriber();
- (0, _swc).teardownCrashReporter();
- return;
- }
- if (state.typeChecking) {
- Log.info(`bundled${partialMessage} successfully${timeMessage}${modulesMessage}, waiting for typecheck results...`);
- return;
- }
- Log.event(`compiled${partialMessage} successfully${timeMessage}${modulesMessage}`);
- // Ensure traces are flushed after each compile in development mode
- (0, _trace).flushAllTraces();
- (0, _swc).teardownTraceSubscriber();
- (0, _swc).teardownCrashReporter();
- });
- //# sourceMappingURL=store.js.map
|