@becklyn/contentful-adapter
Version:
[](https://github.com/Becklyn-Studios/contentful-adapter/actions/workflows/ci.yml)
147 lines (146 loc) • 5.36 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getBlockLogosMigration = exports.VERSION_BLOCK_TEXT_IMAGE = void 0;
const block_1 = require("./block");
const rte_1 = require("../rte");
exports.VERSION_BLOCK_TEXT_IMAGE = {
en: {
default: "Default",
monochrome: "Monochrome",
},
de: {
default: "Standard",
monochrome: "Monochrom",
},
};
const translations = {
en: {
blockLogos: {
name: "🧩 Block > Logos",
fields: {
headline: "Headline",
entries: "Entries",
version: {
name: "Version",
default: exports.VERSION_BLOCK_TEXT_IMAGE.en.default,
in: [
exports.VERSION_BLOCK_TEXT_IMAGE.en.default,
exports.VERSION_BLOCK_TEXT_IMAGE.en.monochrome,
],
},
},
},
blockLogosLogo: {
name: "🧩 Block > Logos > Logo",
fields: {
name: "Internal Name",
image: "Logo",
labeledLink: "Link",
},
},
},
de: {
blockLogos: {
name: "🧩 Block > Logos",
fields: {
headline: "Überschrift",
entries: "Einträge",
version: {
name: "Version",
default: exports.VERSION_BLOCK_TEXT_IMAGE.de.default,
in: [
exports.VERSION_BLOCK_TEXT_IMAGE.de.default,
exports.VERSION_BLOCK_TEXT_IMAGE.de.monochrome,
],
},
},
},
blockLogosLogo: {
name: "🧩 Block > Logos > Logo",
fields: {
name: "Interner Name",
image: "Logo",
labeledLink: "Link",
},
},
},
};
const getBlockLogosMigration = (language) => {
const t = translations[language];
return {
component: "blockLogos",
migrations: {
1: migration => {
const blockLogosLogo = migration.createContentType("blockLogosLogo", {
name: t.blockLogosLogo.name,
});
blockLogosLogo.createField("name", {
type: "Symbol",
name: t.blockLogosLogo.fields.name,
required: true,
});
blockLogosLogo.createField("image", {
type: "Link",
name: t.blockLogosLogo.fields.image,
linkType: "Asset",
validations: [{ linkMimetypeGroup: ["image"] }],
required: true,
});
blockLogosLogo.createField("labeledLink", {
type: "Link",
name: t.blockLogosLogo.fields.labeledLink,
linkType: "Entry",
validations: [{ linkContentType: ["labeledLink"] }],
});
blockLogosLogo.displayField("name");
const blockLogos = migration.createContentType("blockLogos", {
name: t.blockLogos.name,
});
blockLogos.createField("headline", {
type: "Symbol",
name: t.blockLogos.fields.headline,
});
blockLogos.createField("entries", {
type: "Array",
name: t.blockLogos.fields.entries,
items: {
type: "Link",
linkType: "Entry",
validations: [{ linkContentType: ["blockLogosLogo"] }],
},
required: true,
});
(0, block_1.migrateBaseBlockFields)(blockLogos, language);
},
2: migration => {
const blockLogos = migration.editContentType("blockLogos");
blockLogos.deleteField("headline");
blockLogos.createField("headline", {
type: "RichText",
name: t.blockLogos.fields.headline,
validations: (0, rte_1.getRteValidation)(rte_1.RTE_TYPE_HEADLINE),
});
blockLogos.moveField("headline").afterField("name");
},
3: migration => {
const blockLogos = migration.editContentType("blockLogos");
blockLogos.createField("version", {
type: "Symbol",
name: t.blockLogos.fields.version.name,
required: true,
defaultValue: {
[language]: t.blockLogos.fields.version.default,
},
validations: [
{
in: t.blockLogos.fields.version.in,
},
],
});
blockLogos.changeFieldControl("version", "builtin", "radio");
blockLogos.moveField("version").afterField("theme");
},
},
};
};
exports.getBlockLogosMigration = getBlockLogosMigration;