Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@builder.io/qwik

Package Overview
Dependencies
Maintainers
8
Versions
322
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@builder.io/qwik - npm Package Compare versions

Comparing version 0.0.11 to 0.0.12-0

core.cjs.map

86

package.json
{
"name": "@builder.io/qwik",
"version": "0.0.11",
"description": "An Open-Source framework designed for best possible [time to interactive](https://web.dev/interactive/), by focusing on [resumability](./docs/RESUMABLE.md) of server-side-rendering of HTML, and [fine-grained lazy-loading](./docs/LAZY_LOADING.md) of code.",
"version": "0.0.12-0",
"description": "An Open-Source sub-framework designed with a focus on server-side-rendering, lazy-loading, and styling/animation.",
"license": "MIT",
"main": "./core.cjs",
"module": "./core.js",
"module": "./core.mjs",
"types": "./core.d.ts",

@@ -11,7 +12,72 @@ "type": "module",

".": {
"import": "./core.js",
"import": "./core.mjs",
"require": "./core.cjs"
},
"./core": {
"import": "./core.mjs",
"require": "./core.cjs"
},
"./jsx-runtime": {
"import": "./jsx-runtime.mjs",
"require": "./jsx-runtime.cjs"
},
"./optimizer": {
"import": "./optimizer.mjs",
"require": "./optimizer.cjs"
},
"./server": {
"import": "./testing/index.mjs",
"require": "./testing/index.cjs"
},
"./testing": {
"import": "./testing/index.mjs",
"require": "./testing/index.cjs"
},
"./package.json": "./package.json"
},
"files": [
"core.cjs",
"core.cjs.map",
"core.d.ts",
"core.min.mjs",
"core.mjs",
"core.mjs.map",
"jsx-runtime.cjs",
"jsx-runtime.d.ts",
"jsx-runtime.mjs",
"LICENSE",
"optimizer.cjs",
"optimizer.cjs.map",
"optimizer.d.ts",
"optimizer.mjs",
"optimizer.mjs.map",
"package.json",
"qwikloader.debug.js",
"qwikloader.js",
"qwikloader.optimize.debug.js",
"qwikloader.optimize.js",
"README.md",
"server/index.cjs",
"server/index.cjs.map",
"server/index.d.ts",
"server/index.mjs",
"server/index.mjs.map",
"testing/index.cjs",
"testing/index.cjs.map",
"testing/index.d.ts",
"testing/index.mjs",
"testing/index.mjs.map",
"testing/jest-preprocessor.cjs",
"testing/jest-preprocessor.cjs.map",
"testing/jest-preprocessor.mjs",
"testing/jest-preprocessor.mjs.map",
"testing/jest-preset.cjs",
"testing/jest-preset.cjs.map",
"testing/jest-preset.mjs",
"testing/jest-preset.mjs.map",
"testing/jest-setuptestframework.cjs",
"testing/jest-setuptestframework.cjs.map",
"testing/jest-setuptestframework.mjs",
"testing/jest-setuptestframework.mjs.map"
],
"contributors": [

@@ -30,3 +96,2 @@ {

"homepage": "https://github.com/BuilderIO/qwik#readme",
"license": "MIT",
"repository": {

@@ -40,10 +105,17 @@ "type": "git",

"keywords": [
"framework",
"ssr",
"server-side-render",
"prerender",
"ssg",
"static-site-generator",
"static-site",
"generator",
"website",
"webapp",
"framework",
"Builder.io"
],
"engines": {
"node": ">= 14"
"node": ">= 14.14"
}
}

94

qwikloader.js

@@ -1,93 +0,1 @@

"use strict";
/**
* @license
* Copyright Builder.io, Inc. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/BuilderIO/qwik/blob/main/LICENSE
*/
/**
* Set up event listening for browser.
*
* Determine all of the browser events and set up global listeners for them.
* If browser triggers event search for the lazy load URL and `import()` it.
*
* @param document - Document to use for setting up global listeners, and to
* determine all of the browser supported events.
*/
((document) => {
// When cleared it means that `on:q-init` has been run
let readystatechange = 'readystatechange';
/**
* Event handler responsible for processing browser events.
*
* If browser emits an event, the `eventProcessor` walks the DOM tree
* looking for corresponding `(${event.type})`. If found the event's URL
* is parsed and `import()`ed.
*
* @param event - Browser event.
*/
const processEvent = async (event) => {
const eventName = 'on:' + event.type;
let element = event.target;
while (element && element.getAttribute) {
let eventUrl = element.getAttribute(eventName);
if (eventUrl) {
eventUrl = eventUrl.replace(/^(\w+):/, (_, protocol) => {
return window.Q.protocol[protocol];
});
const url = new URL(eventUrl, document.baseURI);
const importPath = url.pathname + '.js';
const module = await import(importPath);
// 1 - optional `#` at the start.
// 2 - capture group `$1` containing the export name, stopping at the first `?`.
// 3 - the rest from the first `?` to the end.
// The hash string is replaced by the captured group that contains only the export name.
// This is the same as in the `qExport()` function.
// 1112222222333
const exportName = url.hash.replace(/^#?([^?]*).*$/, '$1') || 'default';
const handler = module[exportName];
if (!handler)
throw new Error(`QWIKLOADER-ERROR: import '${importPath}' does not export '${exportName}'.`);
handler(element, event, url);
}
element = element.parentElement;
}
};
const addEventListener = (eventName) => {
document.addEventListener(eventName, processEvent, { capture: true });
};
// Set up listeners. Start with `document` and walk up the prototype
// inheritance on look for `on*` properties. Assume that `on*` property
// corresponds to an event browser can emit.
const scriptTag = document.querySelector('script[events]');
if (scriptTag) {
const events = scriptTag.getAttribute('events') || '';
events.split(/[\s,;]+/).forEach(addEventListener);
}
else {
for (const key in document) {
if (key.indexOf('on') == 0) {
const eventName = key.substring(2);
// For each `on*` property, set up a listener.
addEventListener(eventName);
}
}
}
const qInit = `q-init`;
addEventListener(qInit);
const processReadyStateChange = () => {
const readyState = document.readyState;
if (readystatechange && (readyState == 'interactive' || readyState == 'complete')) {
readystatechange = null;
document
.querySelectorAll('[on\\:\\' + qInit + ']')
.forEach((target) => target.dispatchEvent(new CustomEvent(qInit)));
}
};
document.addEventListener(readystatechange, processReadyStateChange);
processReadyStateChange();
})(
// Invoke qwik-loader.
document);
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qwikloader.js","sourceRoot":"./","sources":["qwikloader.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;AAmBH;;;;;;;;GAQG;AACH,CAAC,CAAC,QAAkB,EAAE,EAAE;IACtB,sDAAsD;IACtD,IAAI,gBAAgB,GAAG,kBAAkB,CAAC;IAC1C;;;;;;;;OAQG;IACH,MAAM,YAAY,GAAG,KAAK,EAAE,KAAY,EAAE,EAAE;QAC1C,MAAM,SAAS,GAAG,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;QACrC,IAAI,OAAO,GAAG,KAAK,CAAC,MAAwB,CAAC;QAC7C,OAAO,OAAO,IAAI,OAAO,CAAC,YAAY,EAAE;YACtC,IAAI,QAAQ,GAAG,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;YAC/C,IAAI,QAAQ,EAAE;gBACZ,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;oBACrD,OAAQ,MAAgC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;gBAChE,CAAC,CAAC,CAAC;gBACH,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;gBAChD,MAAM,UAAU,GAAG,GAAG,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACxC,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,UAAU,CAAC,CAAC;gBACxC,iCAAiC;gBACjC,gFAAgF;gBAChF,8CAA8C;gBAC9C,wFAAwF;gBACxF,mDAAmD;gBACnD,kDAAkD;gBAClD,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,IAAI,SAAS,CAAC;gBACxE,MAAM,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;gBACnC,IAAI,CAAC,OAAO;oBACV,MAAM,IAAI,KAAK,CACb,6BAA6B,UAAU,sBAAsB,UAAU,IAAI,CAC5E,CAAC;gBACJ,OAAO,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;aAC9B;YACD,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC;SACjC;IACH,CAAC,CAAC;IACF,MAAM,gBAAgB,GAAG,CAAC,SAAiB,EAAE,EAAE;QAC7C,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IACxE,CAAC,CAAC;IAEF,oEAAoE;IACpE,uEAAuE;IACvE,4CAA4C;IAC5C,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IAC3D,IAAI,SAAS,EAAE;QACb,MAAM,MAAM,GAAG,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtD,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;KACnD;SAAM;QACL,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE;YAC1B,IAAI,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBAC1B,MAAM,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBACnC,8CAA8C;gBAC9C,gBAAgB,CAAC,SAAS,CAAC,CAAC;aAC7B;SACF;KACF;IACD,MAAM,KAAK,GAAG,QAAQ,CAAC;IACvB,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAExB,MAAM,uBAAuB,GAAG,GAAG,EAAE;QACnC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC;QACvC,IAAI,gBAAgB,IAAI,CAAC,UAAU,IAAI,aAAa,IAAI,UAAU,IAAI,UAAU,CAAC,EAAE;YACjF,gBAAgB,GAAG,IAAK,CAAC;YACzB,QAAQ;iBACL,gBAAgB,CAAC,UAAU,GAAG,KAAK,GAAG,GAAG,CAAC;iBAC1C,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SACtE;IACH,CAAC,CAAC;IACF,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,uBAAuB,CAAC,CAAC;IACrE,uBAAuB,EAAE,CAAC;AAC5B,CAAC,CAAC;AACA,sBAAsB;AACtB,QAAQ,CACT,CAAC","sourcesContent":["/**\n * @license\n * Copyright Builder.io, Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/BuilderIO/qwik/blob/main/LICENSE\n */\n\n/**\n * @fileoverview This is qwik-loader.\n *\n * This code should be included too bootstrap qwik sub-framework.\n * The purpose of the qwik-loader is to listen for browser events, find\n * corresponding event handler, and lazy load the code associated with the\n * handler.\n *\n * NOTE: This file relies on side-effect.\n */\n\ninterface QConfig {\n  protocol: {\n    [protocol: string]: string;\n  };\n}\n\n/**\n * Set up event listening for browser.\n *\n * Determine all of the browser events and set up global listeners for them.\n * If browser triggers event search for the lazy load URL and `import()` it.\n *\n * @param document - Document to use for setting up global listeners, and to\n *     determine all of the browser supported events.\n */\n((document: Document) => {\n  // When cleared it means that `on:q-init` has been run\n  let readystatechange = 'readystatechange';\n  /**\n   * Event handler responsible for processing browser events.\n   *\n   * If browser emits an event, the `eventProcessor` walks the DOM tree\n   * looking for corresponding `(${event.type})`. If found the event's URL\n   * is parsed and `import()`ed.\n   *\n   * @param event - Browser event.\n   */\n  const processEvent = async (event: Event) => {\n    const eventName = 'on:' + event.type;\n    let element = event.target as Element | null;\n    while (element && element.getAttribute) {\n      let eventUrl = element.getAttribute(eventName);\n      if (eventUrl) {\n        eventUrl = eventUrl.replace(/^(\\w+):/, (_, protocol) => {\n          return (window as any as { Q: QConfig }).Q.protocol[protocol];\n        });\n        const url = new URL(eventUrl, document.baseURI);\n        const importPath = url.pathname + '.js';\n        const module = await import(importPath);\n        // 1 - optional `#` at the start.\n        // 2 - capture group `$1` containing the export name, stopping at the first `?`.\n        // 3 - the rest from the first `?` to the end.\n        // The hash string is replaced by the captured group that contains only the export name.\n        // This is the same as in the `qExport()` function.\n        //                                   1112222222333\n        const exportName = url.hash.replace(/^#?([^?]*).*$/, '$1') || 'default';\n        const handler = module[exportName];\n        if (!handler)\n          throw new Error(\n            `QWIKLOADER-ERROR: import '${importPath}' does not export '${exportName}'.`\n          );\n        handler(element, event, url);\n      }\n      element = element.parentElement;\n    }\n  };\n  const addEventListener = (eventName: string) => {\n    document.addEventListener(eventName, processEvent, { capture: true });\n  };\n\n  // Set up listeners. Start with `document` and walk up the prototype\n  // inheritance on look for `on*` properties. Assume that `on*` property\n  // corresponds to an event browser can emit.\n  const scriptTag = document.querySelector('script[events]');\n  if (scriptTag) {\n    const events = scriptTag.getAttribute('events') || '';\n    events.split(/[\\s,;]+/).forEach(addEventListener);\n  } else {\n    for (const key in document) {\n      if (key.indexOf('on') == 0) {\n        const eventName = key.substring(2);\n        // For each `on*` property, set up a listener.\n        addEventListener(eventName);\n      }\n    }\n  }\n  const qInit = `q-init`;\n  addEventListener(qInit);\n\n  const processReadyStateChange = () => {\n    const readyState = document.readyState;\n    if (readystatechange && (readyState == 'interactive' || readyState == 'complete')) {\n      readystatechange = null!;\n      document\n        .querySelectorAll('[on\\\\:\\\\' + qInit + ']')\n        .forEach((target) => target.dispatchEvent(new CustomEvent(qInit)));\n    }\n  };\n  document.addEventListener(readystatechange, processReadyStateChange);\n  processReadyStateChange();\n})(\n  // Invoke qwik-loader.\n  document\n);\n"]}
((e,t)=>{const r=(t,r,n)=>t?new URL(t.replace(/^(\w+):(\/)?/,((t,o,a)=>(r=e.querySelector(`[rel="q.protocol.${o}"]`),(n=r&&r.href)||c(o+" not defined"),n+(n.endsWith("/")?"":a||"")))),e.baseURI):0,n=(e,t,r)=>t[r=e.hash.replace(/^#?([^?]*).*$/,"$1")||"default"]||c(e+" does not export "+r),o=async(e,t,o)=>{for(t=e.target;t&&t.getAttribute;)(o=r(t.getAttribute("on:"+e.type)))&&n(o,await import(o.pathname+=".js"))(t,e,o),t=t.parentElement},a=t=>e.addEventListener(t,o,{capture:!0}),i="q-init",s=r=>{r=e.readyState,t||"interactive"!=r&&"complete"!=r||(t=1,e.querySelectorAll("[on\\:\\q-init]").forEach((e=>e.dispatchEvent(new CustomEvent(i)))))},c=e=>{throw Error("QWIK: "+e)};{const t=e.querySelector("script[events]");if(t)(t.getAttribute("events")||"").split(/[\s,;]+/).forEach(a);else for(const t in e)0==t.indexOf("on")&&a(t.substring(2))}a(i),e.addEventListener("readystatechange",s),s()})(document);

@@ -7,4 +7,2 @@ <br />

<br />
# `Qwik` DOM-Centric, Resumable Web-App Framework

@@ -21,9 +19,20 @@

## Blog Posts
- [A first look at Qwik - the HTML first framework](https://dev.to/mhevery/a-first-look-at-qwik-the-html-first-framework-af)
- [Death by Closure (and how Qwik solves it)](https://dev.to/mhevery/death-by-closure-and-how-qwik-solves-it-44jj)
## Development
- See [Developer.md](https://github.com/BuilderIO/qwik/blob/main/DEVELOPER.md) for more information on how to build Qwik from the source and contribute!
## Community
Join our [discord](https://discord.gg/JHVpZmqSs4) community.
- Ping us at [@QwikDev](https://twitter.com/QwikDev)
- Join our [Discord](https://discord.gg/JHVpZmqSs4) community.
<hr />
---
<p align="center">
Made with ❤️ by <a target="_blank" href="https://www.builder.io/">Builder.io</a>
</p>

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc