web:add source loader
This commit is contained in:
parent
17addc232a
commit
ace3d30e73
81
doric-web/dist/index.js
vendored
81
doric-web/dist/index.js
vendored
@ -4402,6 +4402,37 @@ var doric_web = (function (exports, axios, sandbox) {
|
||||
|
||||
var axios__default = /*#__PURE__*/_interopDefaultLegacy(axios);
|
||||
|
||||
var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||
return new (P || (P = Promise))(function (resolve, reject) {
|
||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
const loaders = [
|
||||
{
|
||||
filter: () => true,
|
||||
request: (source) => __awaiter(void 0, void 0, void 0, function* () {
|
||||
const result = yield axios__default['default'].get(source);
|
||||
return result.data;
|
||||
})
|
||||
}
|
||||
];
|
||||
function registerDoricJSLoader(loader) {
|
||||
loaders.push(loader);
|
||||
}
|
||||
function loadDoricJSBundle(source) {
|
||||
return __awaiter(this, void 0, void 0, function* () {
|
||||
const matched = loaders.filter(e => e.filter(source));
|
||||
if (matched.length > 0) {
|
||||
return matched[matched.length - 1].request(source);
|
||||
}
|
||||
throw new Error(`Cannot find matched loader for '${source}'`);
|
||||
});
|
||||
}
|
||||
|
||||
class DoricPlugin {
|
||||
constructor(context) {
|
||||
this.context = context;
|
||||
@ -5788,8 +5819,20 @@ ${content}
|
||||
}
|
||||
return Reflect.apply(sandbox.jsCallEntityMethod, this.panel, argumentsList);
|
||||
}
|
||||
init(extra) {
|
||||
this.invokeEntityMethod("__init__", extra ? JSON.stringify(extra) : undefined);
|
||||
init(data) {
|
||||
this.invokeEntityMethod("__init__", data);
|
||||
}
|
||||
onCreate() {
|
||||
this.invokeEntityMethod("__onCreate__");
|
||||
}
|
||||
onDestroy() {
|
||||
this.invokeEntityMethod("__onDestroy__");
|
||||
}
|
||||
onShow() {
|
||||
this.invokeEntityMethod("__onShow__");
|
||||
}
|
||||
onHidden() {
|
||||
this.invokeEntityMethod("__onHidden__");
|
||||
}
|
||||
build(frame) {
|
||||
this.invokeEntityMethod("__build__", frame);
|
||||
@ -5818,10 +5861,16 @@ ${content}
|
||||
set alias(v) {
|
||||
this.setAttribute('alias', v);
|
||||
}
|
||||
get initData() {
|
||||
return this.getAttribute('data');
|
||||
}
|
||||
set initData(v) {
|
||||
this.setAttribute('data', v);
|
||||
}
|
||||
connectedCallback() {
|
||||
if (this.src && this.context === undefined) {
|
||||
axios__default['default'].get(this.src).then(result => {
|
||||
this.load(result.data);
|
||||
loadDoricJSBundle(this.src).then(result => {
|
||||
this.load(result);
|
||||
});
|
||||
}
|
||||
}
|
||||
@ -5832,11 +5881,14 @@ ${content}
|
||||
attributeChangedCallback() {
|
||||
}
|
||||
onDestroy() {
|
||||
var _a;
|
||||
(_a = this.context) === null || _a === void 0 ? void 0 : _a.teardown();
|
||||
var _a, _b;
|
||||
(_a = this.context) === null || _a === void 0 ? void 0 : _a.onDestroy();
|
||||
(_b = this.context) === null || _b === void 0 ? void 0 : _b.teardown();
|
||||
}
|
||||
load(content) {
|
||||
this.context = new DoricContext(content);
|
||||
this.context.init(this.initData);
|
||||
this.context.onCreate();
|
||||
const divElement = document.createElement('div');
|
||||
divElement.style.position = 'relative';
|
||||
divElement.style.height = '100%';
|
||||
@ -5846,6 +5898,7 @@ ${content}
|
||||
width: divElement.offsetWidth,
|
||||
height: divElement.offsetHeight,
|
||||
});
|
||||
this.context.onShow();
|
||||
}
|
||||
}
|
||||
|
||||
@ -5885,8 +5938,24 @@ ${content}
|
||||
}
|
||||
}
|
||||
|
||||
var __awaiter$1 = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||
return new (P || (P = Promise))(function (resolve, reject) {
|
||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||
});
|
||||
};
|
||||
window.customElements.define('doric-div', DoricElement);
|
||||
window.customElements.define('doric-navigation', NavigationElement);
|
||||
registerDoricJSLoader({
|
||||
filter: (source) => source.startsWith("assets://"),
|
||||
request: (source) => __awaiter$1(void 0, void 0, void 0, function* () {
|
||||
const ret = yield axios__default['default'].get(source.replace("assets://", `${window.location.href}/../../doric-demo/bundle/`));
|
||||
return ret.data;
|
||||
})
|
||||
});
|
||||
|
||||
exports.BOTTOM = BOTTOM;
|
||||
exports.CENTER = CENTER;
|
||||
|
2
doric-web/dist/index.js.map
vendored
2
doric-web/dist/index.js.map
vendored
File diff suppressed because one or more lines are too long
@ -1,3 +1,5 @@
|
||||
import axios from 'axios';
|
||||
import { registerDoricJSLoader } from './src/DoricBundleLoader';
|
||||
import { DoricElement } from './src/DoricElement'
|
||||
import { NavigationElement } from './src/navigate/NavigationElement'
|
||||
window.customElements.define('doric-div', DoricElement);
|
||||
@ -8,3 +10,11 @@ export * from './src/DoricPlugin'
|
||||
export * from './src/DoricRegistry'
|
||||
export * from './src/DoricDriver'
|
||||
export * from './src/shader/DoricViewNode'
|
||||
|
||||
registerDoricJSLoader({
|
||||
filter: (source) => source.startsWith("assets://"),
|
||||
request: async (source) => {
|
||||
const ret = await axios.get(source.replace("assets://", `${window.location.href}/../../doric-demo/bundle/`))
|
||||
return ret.data
|
||||
}
|
||||
})
|
30
doric-web/src/DoricBundleLoader.ts
Normal file
30
doric-web/src/DoricBundleLoader.ts
Normal file
@ -0,0 +1,30 @@
|
||||
import axios from "axios"
|
||||
|
||||
export interface DoricJSLoader {
|
||||
filter(source: string): boolean;
|
||||
request(source: string): Promise<string>;
|
||||
}
|
||||
|
||||
|
||||
const loaders: DoricJSLoader[] = [
|
||||
{
|
||||
filter: () => true,
|
||||
request: async (source) => {
|
||||
const result = await axios.get(source)
|
||||
return result.data;
|
||||
}
|
||||
}
|
||||
];
|
||||
|
||||
export function registerDoricJSLoader(loader: DoricJSLoader) {
|
||||
loaders.push(loader);
|
||||
}
|
||||
|
||||
export async function loadDoricJSBundle(source: string): Promise<string> {
|
||||
const matched = loaders.filter(e => e.filter(source))
|
||||
if (matched.length > 0) {
|
||||
return matched[matched.length - 1].request(source)
|
||||
}
|
||||
throw new Error(`Cannot find matched loader for '${source}'`);
|
||||
|
||||
}
|
@ -1,4 +1,5 @@
|
||||
import axios from 'axios'
|
||||
import { loadDoricJSBundle } from './DoricBundleLoader'
|
||||
import { DoricContext } from './DoricContext'
|
||||
|
||||
|
||||
@ -31,8 +32,8 @@ export class DoricElement extends HTMLElement {
|
||||
|
||||
connectedCallback() {
|
||||
if (this.src && this.context === undefined) {
|
||||
axios.get(this.src).then(result => {
|
||||
this.load(result.data)
|
||||
loadDoricJSBundle(this.src).then(result => {
|
||||
this.load(result)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user