CMS refactor
This commit is contained in:
config.yml
content/german/blog
bundeswettbewerb-fremdsprachen-preisverleihung-auf-landesebene.mdcantor-luft-schnuppern.mdcantorpreisverleihung-2023.mdchemie-modulkurs-2023-der-11-klassen.mdchemie-modulwoche-2023.mderfolge-bei-den-biologie-wettbewerben.mderfolge-bei-der-landesphysikolympiade-2023.mderfolge-beim-german-young-physicists-tournament.mderfolge-in-der-1-runde-der-chemkids-2022-2023.mdergebnisse-3-runde-der-icho-bundesrunde.mdergebnisse-3-runde-der-ipho-bundesrunde.mdfestwoche-2023.mdherzlich-willkommen-auf-der-neuen-homepage-des-georg-cantor-gymnasiums.mdimpressionen-vom-tag-der-offenen-tür-2022.mdinformatik-biber-2022.mdjugend-forscht-das-bundesfinale-2023.mdjugend-forscht-ergebnisse-der-regionalrunde-halle.mdjugend-forscht-landeswettbewerb-2023.mdkanguru-der-mathematik-2023.mdlandeswettbewerb-jugend-debattiert-2023.mdlernfahrt-geschichte-nach-heldrungen.mdmathe-im-advent-2022.mdmathematik-olympiade-landesrunde-2023.mdmottowoche-und-letzter-schultag-des-abiturjahrgangs-2023.mdmusikalisch-literarischer-abend-2023.mdmusikfahrt-2022.mdregionalwettbewerb-jugend-debattiert.mdrezitatorenwettstreit-2023.mdschulausscheid-jugend-debattiert.mdskilager-2023.mdspezialistenlager-2023.mdtag-der-kulturen-2023.mdtoefl-englisch-wettbewerb.mdtransparenzbericht-weihnachtsbasar-spenden.mdvorlesewettbewerb-der-6-klassen-2022-schulrunde.mdweihnachten-2022.mdwettbewerbserfolg-der-letzten-wochen.md
data/de
layouts
static
admin
config.ymlicons.jsindex.html
config
collections
abiturienten.jsauthor.jsbegabte.jsblog.jscantorfora.jscantorpreis.jschronikjahre.jschronikseiten.jsforms.jsganztag.jsindex-pages.jsindex.jspages.jsprojektwoche.jssettings-collection.jsstatistik.jsstats.jssuperhaufen.jswettbewerbe.jswidgets.js
index.jsprops.jsschulchronik.jslinks
previews
field-previews
page-previews
abiturienten-preview.jsabout-preview.jsanmeldeformular-preview.jsanmeldung-preview.jsauthor-preview.jsblog-preview.jscantorpreis-preview.jschronik-index-preview.jschronik-preview.js
components
contest-preview.jsevent-preview.jsforms-preview.jsganztag-preview.jsindex.jskontakt-preview.jspage-preview.jsprojektwoche-preview.jsstyles.jsshortcodes
schulchronik/admin
@ -1,67 +1,67 @@
|
||||
import { Card, TextField } from "./components/index.js";
|
||||
|
||||
const AudioShortcode = {
|
||||
label: "Audiodatei",
|
||||
openTag: "{{< ",
|
||||
closeTag: " >}}",
|
||||
separator: " ",
|
||||
toProps: (args) => {
|
||||
if (args.length > 0) {
|
||||
const src =
|
||||
args
|
||||
.find((arg) => arg.startsWith("src="))
|
||||
?.split("=")[1]
|
||||
.replaceAll('"', "") ?? "";
|
||||
return { src: src };
|
||||
}
|
||||
return { src: "" };
|
||||
},
|
||||
toArgs: ({ src }) => {
|
||||
return [`src=\"${src}\"`];
|
||||
},
|
||||
control: ({ src, onChange, controlProps }) => {
|
||||
const { collection, field } = controlProps;
|
||||
label: "Audiodatei",
|
||||
openTag: "{{< ",
|
||||
closeTag: " >}}",
|
||||
separator: " ",
|
||||
toProps: (args) => {
|
||||
if (args.length > 0) {
|
||||
const src =
|
||||
args
|
||||
.find((arg) => arg.startsWith("src="))
|
||||
?.split("=")[1]
|
||||
.replaceAll('"', "") ?? "";
|
||||
return { src: src };
|
||||
}
|
||||
return { src: "" };
|
||||
},
|
||||
toArgs: ({ src }) => {
|
||||
return [`src=\"${src}\"`];
|
||||
},
|
||||
control: ({ src, onChange, controlProps }) => {
|
||||
const { collection, field } = controlProps;
|
||||
|
||||
const handleChange = ({ path }) => {
|
||||
onChange({ src: path });
|
||||
};
|
||||
const handleChange = ({ path }) => {
|
||||
onChange({ src: path });
|
||||
};
|
||||
|
||||
const handleOpenMediaLibrary = useMediaInsert(
|
||||
src,
|
||||
{ collection, field },
|
||||
handleChange
|
||||
);
|
||||
const handleOpenMediaLibrary = useMediaInsert(
|
||||
src,
|
||||
{ collection, field },
|
||||
handleChange
|
||||
);
|
||||
|
||||
return Card([
|
||||
TextField({
|
||||
label: "Audiodatei",
|
||||
value: src,
|
||||
onChange: (event) => {
|
||||
onChange({ src: event.target.value });
|
||||
},
|
||||
}),
|
||||
h(
|
||||
"span",
|
||||
{ key: "audio-button", className: "flex gap-2 pt-2 px-2" },
|
||||
h(
|
||||
"button",
|
||||
{
|
||||
type: "button",
|
||||
onClick: handleOpenMediaLibrary,
|
||||
className: "btn btn-contained-primary",
|
||||
},
|
||||
"wählen"
|
||||
)
|
||||
),
|
||||
]);
|
||||
},
|
||||
preview: ({ src }) => {
|
||||
return h(
|
||||
"div",
|
||||
{ className: "card" },
|
||||
h("audio", { src: src, controls: true })
|
||||
);
|
||||
},
|
||||
return Card([
|
||||
TextField({
|
||||
label: "Audiodatei",
|
||||
value: src,
|
||||
onChange: (event) => {
|
||||
onChange({ src: event.target.value });
|
||||
},
|
||||
}),
|
||||
h(
|
||||
"span",
|
||||
{ key: "audio-button", className: "flex gap-2 pt-2 px-2" },
|
||||
h(
|
||||
"button",
|
||||
{
|
||||
type: "button",
|
||||
onClick: handleOpenMediaLibrary,
|
||||
className: "btn btn-contained-primary",
|
||||
},
|
||||
"wählen"
|
||||
)
|
||||
),
|
||||
]);
|
||||
},
|
||||
preview: ({ src }) => {
|
||||
return h(
|
||||
"div",
|
||||
{ className: "card" },
|
||||
h("audio", { src: src, controls: true })
|
||||
);
|
||||
},
|
||||
};
|
||||
|
||||
export default AudioShortcode;
|
||||
|
Reference in New Issue
Block a user