diff --git a/app/components/gh-koenig-editor.hbs b/app/components/gh-koenig-editor.hbs
index 67ac40d90..f2df4652e 100644
--- a/app/components/gh-koenig-editor.hbs
+++ b/app/components/gh-koenig-editor.hbs
@@ -52,6 +52,7 @@
@updateSnippet={{@updateSnippet}}
@deleteSnippet={{@deleteSnippet}}
@cardOptions={{@cardOptions}}
+ @postType={{@postType}}
/>
\ No newline at end of file
diff --git a/app/templates/editor.hbs b/app/templates/editor.hbs
index c5d4c789b..1c856bcc9 100644
--- a/app/templates/editor.hbs
+++ b/app/templates/editor.hbs
@@ -92,6 +92,7 @@
@cardOptions={{hash
post=this.post
}}
+ @postType={{this.post.displayName}}
/>
diff --git a/lib/koenig-editor/addon/components/koenig-editor.hbs b/lib/koenig-editor/addon/components/koenig-editor.hbs
index 8bae5cdbd..293a1e053 100644
--- a/lib/koenig-editor/addon/components/koenig-editor.hbs
+++ b/lib/koenig-editor/addon/components/koenig-editor.hbs
@@ -56,6 +56,7 @@
@deleteSnippet={{this.deleteSnippet}}
@replaceWithCardSection={{action "replaceWithCardSection"}}
@replaceWithPost={{action "replaceWithPost"}}
+ @postType={{@postType}}
/>
{{!-- slash menu popup --}}
@@ -66,6 +67,7 @@
@deleteSnippet={{this.deleteSnippet}}
@replaceWithCardSection={{action "replaceWithCardSection"}}
@replaceWithPost={{action "replaceWithPost"}}
+ @postType={{@postType}}
/>
{{!-- all component cards wormholed into the editor canvas --}}
diff --git a/lib/koenig-editor/addon/components/koenig-menu-content.hbs b/lib/koenig-editor/addon/components/koenig-menu-content.hbs
index 542ffbeed..f535c2de8 100644
--- a/lib/koenig-editor/addon/components/koenig-menu-content.hbs
+++ b/lib/koenig-editor/addon/components/koenig-menu-content.hbs
@@ -5,7 +5,7 @@
{{section.title}}
{{#each section.items as |item|}}
- {{#if (card-is-available item)}}
+ {{#if (card-is-available item postType=@postType)}}
{{/if}}
\ No newline at end of file
diff --git a/lib/koenig-editor/addon/helpers/card-is-available.js b/lib/koenig-editor/addon/helpers/card-is-available.js
index a29725706..a7d9974ee 100644
--- a/lib/koenig-editor/addon/helpers/card-is-available.js
+++ b/lib/koenig-editor/addon/helpers/card-is-available.js
@@ -6,7 +6,7 @@ export default class CardIsAvailableHelper extends Helper {
@service config;
@service feature;
- compute([card]) {
+ compute([card], {postType} = {}) {
let cardIsAvailable = true;
if (card.developerExperiment) {
@@ -17,6 +17,10 @@ export default class CardIsAvailableHelper extends Helper {
cardIsAvailable = get(this.feature, card.feature);
}
+ if (postType && card.postType) {
+ cardIsAvailable = card.postType === postType;
+ }
+
return cardIsAvailable;
}
}
diff --git a/lib/koenig-editor/addon/options/cards.js b/lib/koenig-editor/addon/options/cards.js
index 71749a773..61c5514af 100644
--- a/lib/koenig-editor/addon/options/cards.js
+++ b/lib/koenig-editor/addon/options/cards.js
@@ -121,7 +121,8 @@ export const CARD_MENU = [
desc: 'Only visible when delivered by email',
matches: ['email'],
type: 'card',
- replaceArg: 'email'
+ replaceArg: 'email',
+ postType: 'post'
},
{
label: 'Email call to action',
@@ -129,7 +130,8 @@ export const CARD_MENU = [
desc: 'Target free or paid members with a CTA',
matches: ['email', 'cta'],
type: 'card',
- replaceArg: 'email-cta'
+ replaceArg: 'email-cta',
+ postType: 'post'
},
{
label: 'Public preview',