6 Commits

Author SHA1 Message Date
446c9d0f59 2.0.0 2023-03-30 11:08:30 +02:00
a689252f4b BREAKING CHANGE(improved the loading of the environment. Can now be used in sync environments.): update 2023-03-30 11:08:29 +02:00
2f1ce0058c 1.0.12 2023-03-30 11:02:16 +02:00
a49c8e7aa7 fix(core): update 2023-03-30 11:02:15 +02:00
73e5132f2e 1.0.11 2022-09-27 20:04:46 +02:00
13e1d1fcb3 fix(core): update 2022-09-27 20:04:46 +02:00
8 changed files with 8837 additions and 1773 deletions

5956
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
{ {
"name": "@pushrocks/smartntml", "name": "@pushrocks/smartntml",
"version": "1.0.10", "version": "2.0.0",
"private": false, "private": false,
"description": "lit-html for the backend", "description": "lit-html for the backend",
"main": "dist_ts/index.js", "main": "dist_ts/index.js",
@ -13,17 +13,17 @@
"build": "(tsbuild --web)" "build": "(tsbuild --web)"
}, },
"devDependencies": { "devDependencies": {
"@gitzone/tsbuild": "^2.1.25", "@gitzone/tsbuild": "^2.1.65",
"@gitzone/tsbundle": "^2.0.5", "@gitzone/tsbundle": "^2.0.7",
"@gitzone/tstest": "^1.0.44", "@gitzone/tstest": "^1.0.73",
"@pushrocks/tapbundle": "^5.0.3", "@pushrocks/tapbundle": "^5.0.4",
"@types/node": "^18.0.0" "@types/node": "^18.7.23",
"why-is-node-running": "^2.2.2"
}, },
"dependencies": { "dependencies": {
"@happy-dom/global-registrator": "^4.1.0", "@designestate/dees-element": "^2.0.20",
"@pushrocks/smartpromise": "^3.1.7", "@happy-dom/global-registrator": "^8.9.0",
"@types/strip-comments": "^2.0.1", "@pushrocks/smartpromise": "^3.1.7"
"lit": "^2.2.6"
}, },
"browserslist": [ "browserslist": [
"last 1 chrome versions" "last 1 chrome versions"

4562
pnpm-lock.yaml generated Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,20 +1,26 @@
import log from 'why-is-node-running';
import { expect, expectAsync, tap } from '@pushrocks/tapbundle'; import { expect, expectAsync, tap } from '@pushrocks/tapbundle';
import * as smartntml from '../ts/index.js'; import * as smartntml from '../ts/index.js';
let testSmartntmlInstance: smartntml.Smartntml; let testSmartntmlInstance: smartntml.Smartntml;
tap.test('first test', async () => { tap.test('first test', async () => {
testSmartntmlInstance = await smartntml.Smartntml.createAndInit(); testSmartntmlInstance = new smartntml.Smartntml();
}); });
tap.test('should render a string', async () => { tap.test('should render a string', async () => {
const arrayArg = [1, 2, 3, 4, 5, 6]; const arrayArg = [1, 2, 3, 4, 5, 6];
const stringResult = await testSmartntmlInstance.renderTemplateResult(testSmartntmlInstance.html` const stringResult = await testSmartntmlInstance.renderTemplateResult(smartntml.deesElement.html`
<div class="hello">${arrayArg.map( <div class="hello">${arrayArg.map(
(element) => testSmartntmlInstance.html`<div>${element}</div>` (element) => smartntml.deesElement.html`<div>${element}</div>`
)}</div> )}</div>
`); `);
console.log(stringResult); console.log(stringResult);
}); });
tap.test('should log', async () => {
log();
setTimeout(()=> process.exit(0), 0);
})
tap.start(); tap.start();

View File

@ -3,6 +3,6 @@
*/ */
export const commitinfo = { export const commitinfo = {
name: '@pushrocks/smartntml', name: '@pushrocks/smartntml',
version: '1.0.10', version: '2.0.0',
description: 'lit-html for the backend' description: 'lit-html for the backend'
} }

View File

@ -1,48 +1,19 @@
import './instrument/happydom.js';
import * as plugins from './smartntml.plugins.js'; import * as plugins from './smartntml.plugins.js';
import type * as litTypes from 'lit'; const deesElement = plugins.deesElement;
import { unsafeHTML } from 'lit/directives/unsafe-html.js'; export {
export type { TemplateResult } from 'lit'; deesElement
}
export class Smartntml { export class Smartntml {
// STATIC
public static async createAndInit() {
const smartntml = new Smartntml();
await smartntml.init();
return smartntml;
}
private static smartntmlSingletonDeferred: plugins.smartpromise.Deferred<Smartntml>;
public static async createAndInitSingleton() {
if (this.smartntmlSingletonDeferred) {
return this.smartntmlSingletonDeferred.promise;
}
this.smartntmlSingletonDeferred = plugins.smartpromise.defer();
const smartntmlInstance = await this.createAndInit();
this.smartntmlSingletonDeferred.resolve(smartntmlInstance);
return this.smartntmlSingletonDeferred.promise;
}
// INSTANCE
private render: typeof litTypes.render;
public html: typeof litTypes.html;
public unsafeHTML: typeof unsafeHTML;
constructor() { constructor() {
this.init();
} }
public async init() { public async renderTemplateResult(templateResult: plugins.deesElement.TemplateResult, stripCommentsArg = true) {
const lit = await import('lit');
const litUnsafeHtmlDirective = await import('lit/directives/unsafe-html.js');
this.render = lit.render;
this.html = lit.html;
this.unsafeHTML = litUnsafeHtmlDirective.unsafeHTML;
}
public async renderTemplateResult(templateResult: litTypes.TemplateResult, stripCommentsArg = true) {
const element = document.createElement('div'); const element = document.createElement('div');
this.render(templateResult, element); plugins.deesElement.render(templateResult, element);
let stringResult = element.innerHTML; let stringResult = element.innerHTML;
if (stripCommentsArg) { if (stripCommentsArg) {
stringResult = stringResult.replace(/<!--(.*?)-->/g, ''); stringResult = stringResult.replace(/<!--(.*?)-->/g, '');

View File

@ -0,0 +1,4 @@
// happy-dom setup
import { GlobalRegistrator } from '@happy-dom/global-registrator';
GlobalRegistrator.register();
window.location.href = 'http://localhost';

View File

@ -1,7 +1,3 @@
// happy-dom setup
import { GlobalRegistrator } from '@happy-dom/global-registrator';
GlobalRegistrator.register();
// @pushrocks scope // @pushrocks scope
import * as smartpromise from '@pushrocks/smartpromise'; import * as smartpromise from '@pushrocks/smartpromise';
@ -9,4 +5,11 @@ export {
smartpromise smartpromise
} }
// designestate
import * as deesElement from '@designestate/dees-element';
export {
deesElement
}
// third party scope // third party scope