Files
@ a1f1653e3d5b
Branch filter:
Location: light9/web/effects/Light9EffectListing.ts - annotation
a1f1653e3d5b
3.2 KiB
video/MP2T
new dep
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();
}
}
|