Files
@ 4682f604b245
Branch filter:
Location: light9/web/effects/Light9EffectListing.ts - annotation
4682f604b245
3.2 KiB
video/MP2T
dead code
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 | 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 4556eebe5d73 | import debug from "debug";
import { css, html, LitElement } from "lit";
import { customElement } from "lit/decorators.js";
import { NamedNode } from "n3";
import { sortBy } from "underscore";
import { getTopGraph } from "../RdfdbSyncedGraph";
import { SyncedGraph } from "../SyncedGraph";
export { ResourceDisplay } from "../ResourceDisplay";
debug.enable("*");
const log = debug("listing");
@customElement("light9-effect-listing")
export class Light9EffectListing extends LitElement {
render() {
return html`
<h1>Effects</h1>
<rdfdb-synced-graph></rdfdb-synced-graph>
${this.effects.map((e: NamedNode) => html`<light9-effect-class .uri=${e}></light9-effect-class>`)}
`;
}
graph!: SyncedGraph;
effects: NamedNode[] = [];
constructor() {
super();
getTopGraph().then((g) => {
this.graph = g;
this.graph.runHandler(this.getClasses.bind(this), "getClasses");
});
}
getClasses() {
const U = this.graph.U();
this.effects = this.graph.subjects(U("rdf:type"), U(":Effect")) as NamedNode[];
this.effects = sortBy(this.effects, (ec: NamedNode) => {
try {
return this.graph.stringValue(ec, U("rdfs:label"));
} catch (e) {
return ec.value;
}
});
this.requestUpdate();
}
}
@customElement("light9-effect-class")
export class Light9EffectClass extends LitElement {
static styles = [
css`
:host {
display: block;
padding: 5px;
border: 1px solid green;
background: #1e271e;
margin-bottom: 3px;
}
a {
color: #7992d0;
background: #00000859;
min-width: 4em;
min-height: 2em;
display: inline-block;
text-align: center;
vertical-align: middle;
}
resource-display {
min-width: 12em;
font-size: 180%;
}
`,
];
render() {
if (!this.uri) {
return html`loading...`;
}
return html`
Effect
<resource-display .uri=${this.uri} rename></resource-display>
<a href="../live?effect=${this.uri.value}">Edit</a>
<iron-ajax id="songEffects" url="/effectEval/songEffects" method="POST" content-type="application/x-www-form-urlencoded"></iron-ajax>
<span style="float:right">
<button disabled @click=${this.onAdd}>Add to current song</button>
<button disabled @mousedown=${this.onMomentaryPress} @mouseup=${this.onMomentaryRelease}>Add momentary</button>
</span>
`;
}
graph!: SyncedGraph;
uri?: NamedNode;
onAdd() {
// this.$.songEffects.body = { drop: this.uri.value };
// this.$.songEffects.generateRequest();
}
onMomentaryPress() {
// this.$.songEffects.body = { drop: this.uri.value, event: "start" };
// this.lastPress = this.$.songEffects.generateRequest();
// return this.lastPress.completes.then((request: { response: { note: any } }) => {
// return (this.lastMomentaryNote = request.response.note);
// });
}
onMomentaryRelease() {
// if (!this.lastMomentaryNote) {
// return;
// }
// this.$.songEffects.body = { drop: this.uri.value, note: this.lastMomentaryNote };
// this.lastMomentaryNote = null;
// return this.$.songEffects.generateRequest();
}
}
|