-
Notifications
You must be signed in to change notification settings - Fork 48
Expand file tree
/
Copy pathloader.ts
More file actions
147 lines (134 loc) · 4.07 KB
/
loader.ts
File metadata and controls
147 lines (134 loc) · 4.07 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
import * as paneRegistry from 'pane-registry'
import * as $rdf from 'rdflib'
import { solidLogicSingleton, store, authSession } from 'solid-logic'
import { getOutliner } from '../src'
import { formPane as Pane } from '../src/form/pane'
import './dev-mash.css'
function registerPaneModule (moduleOrPane: any) {
const pane = moduleOrPane?.default || moduleOrPane
paneRegistry.register(pane)
}
async function preloadFormOntologies () {
const ontologyDocs = [
'https://www.w3.org/ns/ui.ttl'
]
await Promise.all(
ontologyDocs.map(async uri => {
try {
await store.fetcher.load($rdf.sym(uri))
} catch (error) {
console.warn('Could not preload ontology:', uri, error)
}
})
)
}
// Add custom properties to the Window interface for TypeScript
declare global {
interface Window {
logout: () => void;
login: () => Promise<void>;
renderPane: typeof renderPane;
Pane: typeof Pane;
}
}
async function renderPane (uri: string) {
if (!uri) {
console.log("usage renderPane('http://example.com/#this')", uri)
return
}
const subject = $rdf.sym(uri)
const doc = subject.doc()
const paneSubject = Pane.name === 'dataContents' ? doc : subject
const target = document.getElementById('render')
try {
await new Promise((resolve, reject) => {
store.fetcher.load(doc).then(resolve, reject)
})
} catch (error) {
console.error('Failed to load document for pane rendering', error)
if (target) {
target.innerHTML = `<pre>Failed to load ${doc.uri}\n${String(error)}</pre>`
}
return
}
const context = {
// see https://github.com/solidos/solid-panes/blob/005f90295d83e499fd626bd84aeb3df10135d5c1/src/index.ts#L30-L34
dom: document,
getOutliner,
session: {
store: store,
paneRegistry,
logic: solidLogicSingleton
}
}
console.log(subject, context)
try {
const icon = createIconElement(Pane)
const paneDiv = Pane.render(paneSubject, context, {})
if (target) {
target.innerHTML = ''
target.appendChild(icon)
target.appendChild(paneDiv)
} else {
console.error("Element with id 'render' not found.")
}
} catch (error) {
console.error('Pane render failed', error)
if (target) {
target.innerHTML = `<pre>Pane render failed\n${String(error)}</pre>`
}
}
}
function createIconElement (Pane: { icon: string }) {
const icon = Pane.icon
const img = document.createElement('img')
img.src = icon
img.width = 40
return img
}
window.onload = async () => {
console.log('document ready')
// registerPanes((cjsOrEsModule: any) => paneRegistry.register(cjsOrEsModule.default || cjsOrEsModule))
registerPaneModule(Pane)
registerPaneModule(require('contacts-pane'))
await preloadFormOntologies()
await authSession.handleIncomingRedirect({
restorePreviousSession: true
})
const session = await authSession
if (!session.info.isLoggedIn) {
console.log('The user is not logged in')
const loginBanner = document.getElementById('loginBanner');
if (loginBanner) {
loginBanner.innerHTML = '<button onclick="login()">Log in</button>';
}
} else {
console.log(`Logged in as ${session.info.webId}`)
const loginBanner = document.getElementById('loginBanner');
if (loginBanner) {
loginBanner.innerHTML = `Logged in as ${session.info.webId} <button onclick="logout()">Log out</button>`;
}
}
renderPane('https://sstratsianis.solidcommunity.net/formtest.ttl#this')
}
window.logout = () => {
authSession.logout()
window.location.href = ''
}
window.login = async function () {
const session = await authSession
if (!session.info.isLoggedIn) {
const issuer = prompt('Please enter an issuer URI', 'https://solidcommunity.net')
if (issuer) {
await authSession.login({
oidcIssuer: issuer,
redirectUrl: window.location.href,
clientName: 'Solid Panes Dev Loader'
})
} else {
console.warn('Login cancelled: No issuer provided.')
}
}
};
(window as any).renderPane = renderPane
console.log("Pane at runtime:", Pane); window.Pane = Pane;