A horizontal flip card (reusable block)

Hi! Here is a Flip card in Sitejet (my first reusable block)
CleanShot 2021-07-05 at 17.34.42

Block data - to import this in SiteJet

  1. Copy the Block data (from below) into Clipboard,
  2. Go to your project in the SiteJet CMS and press on the Import → SiteJet from th Bookmark Bar (Read more here)
  3. A modal will appear, Paste the data inside the input field and press OK
  4. Now, if everything went well the data will be decoded and placed in SiteJet Clipboard format
  5. Use the Paste option from SiteJet to place the block where you need
  6. Copy CSS (or additional code) by selecting the CSS below and then Paste the (S)CSS in SiteJet → CSS panel

Block data

{"contents":[{"source":{"id":"64921363","page":2244683,"webcard":329515,"language":"en"},"type":"container","content":"<div class=\"ed-element ed-container wv-boxed wv-spacer preset-columns-three-v2-default\" style=\"\" data-from-preset=\"columns-three-v2\" data-min-count=\"1\" data-max-count=\"1\" data-mappable=\"1\" data-origin=\"64921363\" ><div class=\"inner\"><div class=\"ed-element ed-container columns-box wv-overflow_visible\" style=\"\" data-from-preset=\"\" data-min-count=\"1\" data-max-count=\"99\" data-mappable=\"1\" ><div class=\"inner\"><div class=\"ed-element ed-container flip-card\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" ><div class=\"inner\"><div class=\"ed-element ed-container flip-card-front full-width wv-boxed\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" style=\"background-color: rgb(249, 221, 205);\" ><div class=\"inner\"><div class=\"ed-element ed-headline custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-origin=\"64921388\" data-mappable=\"true\" ><h2>Front</h2><style>#ed-new-2798 h2 { text-align: center; }</style></div><div class=\"ed-element ed-text custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" ><p style=\"text-align: center;\">This is the front</p></div></div><style>#ed-new-2797 > .inner { place-content: center; } #ed-new-2797 { min-height: 300px; }</style></div><div class=\"ed-element ed-container flip-card-back full-width wv-boxed\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" style=\"background-color: rgb(237, 237, 237);\" ><div class=\"inner\"><div class=\"ed-element ed-headline custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" ><h2>Back</h2><style>#ed-new-2801 h2 { text-align: center; }</style></div><div class=\"ed-element ed-text custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" ><p style=\"text-align: center;\">This is the back</p></div></div><style>#ed-new-2800 > .inner { align-content: center; } #ed-new-2800 { min-height: 300px; }</style></div></div></div></div></div><div class=\"ed-element ed-container columns-box wv-overflow_visible\" style=\"\" data-from-preset=\"\" data-min-count=\"1\" data-max-count=\"99\" data-mappable=\"1\" data-origin=\"64921366\" ><div class=\"inner\"><div class=\"ed-element ed-dummy\" style=\"color: rgb(51, 51, 51); border: 3px dashed rgb(207, 207, 207); margin: 0px; padding: 20px 10%; overflow: hidden; font-size: 16px; text-align: center; font-family: Arial, sans-serif; line-height: 20px; text-shadow: rgba(255, 255, 255, 0.5) 1px 0px, rgba(255, 255, 255, 0.5) 0px 1px, rgba(255, 255, 255, 0.5) -1px 0px, rgba(255, 255, 255, 0.5) 0px -1px; text-overflow: ellipsis; text-transform: none; letter-spacing: 0px; font-style: normal; font-weight: 400;\">Drop content here<span style=\"display:block; margin: 10px 0;font-size: 0.85em;\">or</span><span class=\"wv-add-element\" style=\"display: inline-flex; place-content: center; align-items: center; cursor: pointer; pointer-events: auto; background: rgba(0,0,0,0.05); border-radius: 24px; margin: 4px; padding: 4px 8px; font-size: 0.85em;\"><i class=\"fa fa-plus\"></i>&nbsp;Add content</span><span class=\"wv-paste\" style=\"display: inline-flex; place-content: center; align-items: center; cursor: pointer; pointer-events: auto;background: rgba(0,0,0,0.05); border-radius: 24px; margin: 4px; padding: 4px 8px; font-size: 0.85em;\"><i class=\"fa fa-clipboard\"></i>&nbsp;Paste clipboard</span></div></div></div><div class=\"ed-element ed-container columns-box wv-overflow_visible\" style=\"\" data-from-preset=\"\" data-min-count=\"1\" data-max-count=\"99\" data-mappable=\"1\" data-origin=\"64921366\" ><div class=\"inner\"><div class=\"ed-element ed-dummy\" style=\"color: rgb(51, 51, 51); border: 3px dashed rgb(207, 207, 207); margin: 0px; padding: 20px 10%; overflow: hidden; font-size: 16px; text-align: center; font-family: Arial, sans-serif; line-height: 20px; text-shadow: rgba(255, 255, 255, 0.5) 1px 0px, rgba(255, 255, 255, 0.5) 0px 1px, rgba(255, 255, 255, 0.5) -1px 0px, rgba(255, 255, 255, 0.5) 0px -1px; text-overflow: ellipsis; text-transform: none; letter-spacing: 0px; font-style: normal; font-weight: 400;\">Drop content here<span style=\"display:block; margin: 10px 0;font-size: 0.85em;\">or</span><span class=\"wv-add-element\" style=\"display: inline-flex; place-content: center; align-items: center; cursor: pointer; pointer-events: auto; background: rgba(0,0,0,0.05); border-radius: 24px; margin: 4px; padding: 4px 8px; font-size: 0.85em;\"><i class=\"fa fa-plus\"></i>&nbsp;Add content</span><span class=\"wv-paste\" style=\"display: inline-flex; place-content: center; align-items: center; cursor: pointer; pointer-events: auto;background: rgba(0,0,0,0.05); border-radius: 24px; margin: 4px; padding: 4px 8px; font-size: 0.85em;\"><i class=\"fa fa-clipboard\"></i>&nbsp;Paste clipboard</span></div></div></div></div></div>","sort":0},{"source":{"id":"64921373","page":2244683,"webcard":329515,"language":"en"},"type":"container","content":"<div class=\"ed-element ed-container flip-card\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\"  data-origin=\"64921373\"><div class=\"inner\"><div class=\"ed-element ed-container flip-card-front full-width wv-boxed\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" style=\"background-color: rgb(249, 221, 205);\" ><div class=\"inner\"><div class=\"ed-element ed-headline custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-origin=\"64921388\" data-mappable=\"true\" ><h2>Front</h2><style>#ed-new-2789 h2 { text-align: center; }</style></div><div class=\"ed-element ed-text custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" ><p style=\"text-align: center;\">This is the front</p></div></div><style>#ed-new-2788 > .inner { place-content: center; } #ed-new-2788 { min-height: 300px; }</style></div><div class=\"ed-element ed-container flip-card-back full-width wv-boxed\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" style=\"background-color: rgb(237, 237, 237);\" ><div class=\"inner\"><div class=\"ed-element ed-headline custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" ><h2>Back</h2><style>#ed-new-2792 h2 { text-align: center; }</style></div><div class=\"ed-element ed-text custom-theme\" data-max-count=\"1\" data-min-count=\"1\" data-mappable=\"true\" ><p style=\"text-align: center;\">This is the back</p></div></div><style>#ed-new-2791 > .inner { align-content: center; } #ed-new-2791 { min-height: 300px; }</style></div></div></div>","sort":2}],"hasPreset":true}

Custom CSS

//Flip card
body:not(.edit) {
  .flip-card {
    background-color: transparent;
    width: 100%;
    height: 300px; // Same size as the side
    perspective: 1000px; // Remove this if you don't want the 3D effect
    overflow: visible;
    position: relative;
    // This container is needed to position the front and back side
    .inner {
      position: relative;
      transition: transform 0.8s;
      transform-style: preserve-3d;
    }

    &:hover {
      > .inner {
        // Do an horizontal flip when you move the mouse over the flip box container
        transform: rotateY(180deg);
      }
    }

    // Position the front and back side
    .flip-card-front,
    .flip-card-back {
      position: absolute;
      width: 100%;
      height: 100%;
      -webkit-backface-visibility: hidden; //Safari
      backface-visibility: hidden;
      > .inner {
        width: 100%;
        height: 100%;
        //Align inner content
        display: flex;
        align-items: center;
        justify-content: center;
      }
    }

    //Style the front side
    .flip-card-front {
    }
    //Style the back side
    .flip-card-back {
      transform: rotateY(180deg);
    }
  }
}
5 Likes

Hi @Lucian_Dinu great work! Just moved it to “share components” :slight_smile:

2 Likes