Model Examples
No edit summary
No edit summary
Tag: 2017 source edit
 
(179 intermediate revisions by 5 users not shown)
Line 1: Line 1:
<html>
<html>
<style>
<style>
    @media (max-width: 767px) {
.headerContent {
        .content {
width: 100%;
            padding: 2em 1em;
display: flex;
            max-width: none;
flex-direction: column;
        }
gap: 10px;
        .heading {
box-sizing: border-box;
            font-size: 1.5em;
padding: 5em;
        }
}
        .sub-heading {
.heading {
            font-size: 1em;
color: #112B3C;
        }
font-size: 2.25em;
        .description {
font-weight: 700;
            font-size: 0.875em;
text-transform: uppercase;
        }
}
        .input-container {
.description, .sub-heading, .search-input {
            max-width: none;
font-size: 16px;
            height: auto;
}
        }
        .search-icon {
            margin-left: 1em;
        }
        .search-input {
            padding-left: 1em;
            padding-right: 1em;
        }
    }
</style>


<div>
.container-model {
  <div class="content" style="padding: 5em;  width: 100%; display: flex; flex-direction: column; gap: 10px; box-sizing: border-box;">
display: flex;
<div style="color: #44546F;">Model Samples</div>
padding-left: 5em;
    <div class="heading" style="color: #F67A07; font-size: 2.25em;  font-weight: 700; text-transform: uppercase; ">MODEL SAMPLES</div>
padding-right: 5em;
  <div style="width: 568px"><span  style="color: black; font-size: 16px; font-weight: 400; word-wrap: break-word">Get started with MDriven sample models.
background-color: #F3F6F9;
Explore our models and choose what you want to build..</span></div>
padding-top: 1.5rem;
</div>
</div>
<style>
body, html {
  margin: 0;
  padding: 0;
  font-family: 'Outfit', sans-serif;
}
}


.container {
.mw-parser-output > *:first-child {
  display: flex;
display: none;
}
}


.sidebar {
.sidebar {
  flex: 0 0 200px; /* Adjust the width as needed */
    flex: 0 0 200px;
  padding: 20px;
    padding: 20px;
  display: flex;
    display: flex;
  flex-direction: column;
    flex-direction: column;
    margin-top:50px;
    height: fit-content;
    position: sticky;
    top: 120px;
}
}


.menu-item {
.menu-item {
  color: #0060A8;
color: #0060A8;
  font-size: 16px;
font-size: 16px;
  font-weight: 500;
font-weight: 500;
  margin-bottom: 10px; /* Space between menu items */
margin-bottom: 10px;
  word-wrap: break-word;
word-wrap: break-word;
}
}


.card-container , .card-container-3 {
.card-container, .card-container-3 {
  display: grid;
    display: flex;
  grid-template-columns: repeat(3, 1fr);
    gap: 32px;
  grid-gap: 32px;
    max-width: 1140px;
  margin: 0 auto;
    margin-top: 1rem;
  max-width: 960px;
    margin-bottom: 2rem;
    flex-wrap: wrap;
    height: fit-content;
 
}
}


.cards {
.cards {
  width: 296px;
width: 296px;
  background: white;
background: white;
  border-radius: 6px;
border-radius: 6px;
  border: 1px solid #E3E8EE;
border: 1px solid #E3E8EE;
  display: flex;
display: flex;
  flex-direction: column;
flex-direction: column;
  align-items: center;
align-items: center;
  margin-bottom: 32px; /* Space between card rows */
padding:1px;
}
}


.card img {
.card img {
  width: 100%;
width: 100%;
  border-top-left-radius: 6px;
border-top-left-radius: 6px;
  border-top-right-radius: 6px;
border-top-right-radius: 6px;
}
 
.contentss {
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
}


.title {
.title {
  color: #112B3C;
color: #112B3C;
  font-size: 20px;
font-size: 18px;
  font-weight: 700;
font-weight: 700;
  margin-bottom: 10px; /* Adjust as needed */
}
}


.description {
.description {
  font-size: 14px;
font-size: 14px;
  font-weight: 300;
font-weight: 300;
  color: black;
color: black;
}
}


.download-link {
.download-link {
  display: flex;
display: inline-flex;
  align-items: center;
align-items: center;
  gap: 6px;
gap: 6px;
  color: #F67A07;
color: #F67A07;
  font-size: 14px;
font-size: 14px;
  font-weight: 600;
font-weight: 600;
text-decoration: none;
transition: background-color 0.3s, color 0.3s;
}
}


.download-indicator {
.download-indicator {
  width: 12px;
width: 14px;
  height: 12px;
height: 15px;
  background: #F67A07;
display: block;
  transform: rotate(-90deg);
background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="15" viewBox="0 0 14 15" fill="none"><path d="M1 10.6094L1 11.3594C1 12.602 2.00736 13.6094 3.25 13.6094L10.75 13.6094C11.9926 13.6094 13 12.602 13 11.3594L13 10.6094M10 7.60937L7 10.6094M7 10.6094L4 7.60937M7 10.6094L7 1.60937" stroke="%23F77A07" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  border: 2px solid #F67A07;
background-size: contain;
background-repeat: no-repeat;
background-position: center;
}
 
.sidebar a {
display: flex;
color: #182933;
text-decoration: none;
margin-bottom: 10px;
padding-left: 20px;
position: relative;
font-weight: 500;
align-items: center;
}
 
.sidebar a.active {
color: #1A50AD;
}
}


  .sidebar a {
.sidebar a.active svg {
     display: block;
position: absolute;
     color: #182933;
left: 0;
     text-decoration: none;
top: 4px;
     margin-bottom: 10px;
}
    padding-left: 20px;  
 
    position: relative;
@media (max-width: 768px) {
    font-weight: 500;
.sidebar, .search-container {
  }
display: none;
}
 
.card-container, .card-container-3 {
     padding: 0 15px;
     gap: 20px;
     flex-direction: column;
     align-items: center;
}
 
.cards {
margin-bottom: 20px;
width: auto;
max-width: 296px;
box-sizing: border-box;
}


  .sidebar a.active {
.headerContent,
    color: #1A50AD;  
.container-model {
  }
padding: 2em 1em;
}
.heading {
font-size: 1.5em;
}
.sub-heading {
font-size: 1em;
}
.description {
font-size: 0.875em;
}
}


  .sidebar a.active svg {
.contentss {
    position: absolute;
padding: 1rem;
    left: 0;
gap: 6px;
    top: 0;
display: flex;
  }
flex-direction: column;
width:100%;
}


@media screen and (max-width: 768px) {
.search-container {
    .container {
display: flex;
      flex-direction: column;
align-items: center;
    }
border-radius: 4px;
border: 1px solid #E3E8EE;
background: #FFF;
width: 100%;
height: 36px;
max-width: 952px;
flex-shrink: 0;
}


    .sidebar {
.search-container input[type="search"] {
      width: 100%;
border: none;
      flex-direction: row;
outline: none;
      overflow-x: auto;
padding: 0 10px;
      white-space: nowrap;
height: 100%;
      padding-bottom: 10px;
width:100%;
      box-sizing: border-box;  
color: #999B9E;
    }
}


    .sidebar .menu-item {
.search-container svg {
      display: inline-block;
margin: 0 10px;
      margin-right: 10px;  
}
    }


    .card-container, .card-container-3 {
.search-container input::placeholder {
      grid-template-columns: 1fr;
color: #999B9E;
      padding: 0 20px;
}
      max-width: none;
    }


    .cards {
.search-container input:focus {
      width: auto;
border: none;
    }
outline: none;
}
h2 {
border-bottom: none;
}
.section-divider {
border: 0;
height: 1px;
background-color: #E3E8EE;
margin: 20px 0;
}


    .menu-item {
@media (max-width: 600px) {
      padding: 10px;
.cards {
      font-size: 14px;
flex-direction: column;
    }
}


    section h2, .card-container {
.title, .description {
      margin-left: 0;
font-size: 16px;
    }
}
  }


@media (max-width: 768px) {
.download-link {
    .sidebar,
font-size: 12px;
    .card-container,
padding: 8px 12px;
    .card-container-3 {
}
      flex: 0 0 100%;
}
      max-width: 100%;
      margin-left: 0;
    }


    .card-container,
    .card-container-3 {
      grid-template-columns: 1fr;
    }
  }


  .search-container {
    display: flex;
    align-items: center;
    border-radius: 4px;
    border: 1px solid #E3E8EE;
    background: #FFF;
    width: 951px;
    height: 36px;
    flex-shrink: 0;
  }
 
  .search-container input[type="search"] {
    border: none;
    outline: none;
    width: 100%;
    padding: 0 10px;
    height: 100%;
    color: #999B9E; /* Placeholder text color */
  }
 
  .search-container svg {
    margin: 0 10px;
  }
 
  /* Change placeholder color */
  .search-container input::placeholder {
    color: #999B9E;
  }
 
  /* If you want to ensure that the input does not have border in any browser */
  .search-container input:focus {
    border: none;
    outline: none;
  }
</style>
</style>
</head>
<body>


<div class="container">
<div class="headerContent">
  <div class="sidebar">
    <div style="color:#44546F;">Model examples</div>
    <!-- Menu items -->
    <div class="heading">BROWSE MODEL SAMPLES</div>
    <a href="#complete-models" class="menu-item">Complete models</a>
    <div class="description" style="color: black; font-weight: 400; word-wrap: break-word">
  <a href="#another-model" class="menu-item">Another model</a>
        Get started with MDriven sample models and packages. Explore and select what you want to build.
  <a href="#final-model" class="menu-item">Final model</a>
    </div>
  </div>
    <div class="description" style="color: black; font-weight: 650; word-wrap: break-word">
<main>
    </div>
<div class="search-container">
  <svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 14 14" fill="none">
    <path d="M13 13L9 9L13 13ZM10.3333 5.66667C10.3333 8.244 8.244 10.3333 5.66667 10.3333C3.08934 10.3333 1 8.244 1 5.66667C1 3.08934 3.08934 1 5.66667 1C8.244 1 10.3333 3.08934 10.3333 5.66667Z" stroke="#999B9E" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
  </svg>
  <input type="search" id="searchBox" onkeyup="searchCards()" placeholder="Search here...">
</div>
</div>
<div class="container-model">
    <!-- Section for Complete Models -->
    <div class="sidebar">
<section id="complete-models">
      <!-- Menu items -->
      <h2>Complete Models</h2>
      <a href="#complete-models" class="menu-item">Complete models</a>
  <div class="card-container">
    <a href="#another-model" class="menu-item">Patterns</a>
    <!-- Card 1 -->
    <a href="#final-model" class="menu-item">Extensions</a>
    <div class="cards">
      <img src="https://via.placeholder.com/301x175" alt="Placeholder">
      <div class="contentss">
        <div class="title">Base App</div>
        <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
        <div class="download-link">
          <div class="download-indicator"></div>
          <div>Download .zip</div>
        </div>
      </div>
     </div>
     </div>
    <!-- Card 2 -->
  <main>
    <!-- Repeat the structure for other cards as needed -->
  <div class="search-container" style="display: flex;align-items: center;border-radius: 4px; border: 1px solid #E3E8EE;background: #FFF;width: 100%;height: 36px; flex-shrink: 0;">
    <!-- ... -->
    <svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 14 14" fill="none">
    <div class="cards">
      <path d="M13 13L9 9L13 13ZM10.3333 5.66667C10.3333 8.244 8.244 10.3333 5.66667 10.3333C3.08934 10.3333 1 8.244 1 5.66667C1 3.08934 3.08934 1 5.66667 1C8.244 1 10.3333 3.08934 10.3333 5.66667Z" stroke="#999B9E" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
    </svg>
        <div class="contentss">
    <input type="search" id="searchBox" onkeyup="searchCards()" placeholder="Search here...">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
   </div>
   </div>
 
      <!-- Section for Complete Models -->
  <section id="complete-models">
        <h2>Complete Models</h2>
<div style="color: black; font-size: 16px; font-weight: 400; word-wrap: break-word">Use ready-made  "complete system"  (model+data) to apply to an existing turnkey site.</span><a
href="#" style="color: #1A50AD; font-size: 16px;  font-weight: 500; text-decoration: underline; word-wrap: break-word"> <a href='https://wiki.mdriven.net/Complete_model_examples'> How to merge modlr files?</a></div>
    <div class="card-container">
</html>
{{#widget:Models|img=/Special:Filepath/File:2021-04-13_09h30_34.png|title=Gantt Chart Interactive|description=Use this when you need to show and interact with data in a timeline.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/GanttChartInteractive.modlr|label=Download Modlr file}}
{{#widget:Models|img=/Special:Filepath/File:2020-05-31_22h59_58.png|title=A Trello-like Board With Cards You Can Move Between Lists|description=Move cards between lists, click cards, add new cards and more.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/TrelloLikeBoard.modlr|label=Download Modlr file}}
{{#widget:Models|img=/Special:Filepath/File:2021-04-02_17h00_48.png|title=Markup Editor TinyMCE|description=Lets your users produce rich HTML text.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/HtmlEditor.modlr|label=Download Modlr file}}
{{#widget:Models|img=/Special:Filepath/File:2020-05-31_17h14_29.png|title=SVG - Move boxes around|description=Objects represented by SVG graphics that react to mouse events so that they can be moved around and saved.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/SvgInteractionMoveBoxesAround.modlr|label=Download Modlr file}}
{{#widget:Models|img=/Special:Filepath/File:2020-05-31_19h31_33.png|title=Google Maps to Show and Update Positions|description=Place a marker on a Google map, track the setting of the map, and move the marker.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/GoogleMapWithMarkers.modlr|label=Download Modlr file}}
<html>
</div>
  </section>
<hr class="section-divider" />
  <!-- Section for Patterns -->
  <section id="another-model">
        <h2>Patterns</h2>
<div><span style="color: black; font-size: 16px; font-weight: 400; word-wrap: break-word">Packages primarily used by importing into an existing model. </span><a
href="#" style="color: #1A50AD; font-size: 16px;  font-weight: 500; text-decoration: underline; word-wrap: break-word"> <a href='https://wiki.mdriven.net/Documentation:Model_Examples_Old'> How to merge modlr files?</a></div>
    <div class="card-container">
</html>
{{#widget:Models|img=/Special:Filepath/File:2020-05-30_19h31_20.png|title=SysUserAuthentication - important architectural pattern|description=This example adds the SysSingleton and SysUser classes needed to enable login and authentication in Turnkey systems.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/SysUserAuthentication.modlr|label=Download this pattern}}
{{#widget:Models|img=/Special:Filepath/File:Password_reset_model_sample.png|title=Password Reset Sample - Architectural Pattern|description=Add this functionality to your model and this frees you to integrate and adapt it as needed.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/PasswordResetTemplate.modlr|label=Download this pattern}}
{{#widget:Models|img=/Special:Filepath/File:2020-06-30_20h04_31.png|title=SysAsyncTicket - Important Architectural Pattern|description=A model pattern you can easily add to your model, backed by recent MDrivenServers.|downloadLink=https://learn.mdriven.net/SysAsync_package|label=Go to the SysAsyncTicket page}}
{{#widget:Models|img=/Special:Filepath/File:2020-06-17_15h43_02.png|title=Localization and Translation - Architectural Pattern|description=MDriven systems can adhere to a model pattern and use that to store translations to all texts in actions and ViewModels.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/Translations.modlr|label=Download this pattern}}
{{#widget:Models|img=/Special:Filepath/File:2022-07-19_13h48_16.png|title=SysTurnkeyTraceLog|description=Add a class following this pattern if you need to track what users are up to in your Turnkey app.|downloadLink=https://github.com/supportMDriven/MDrivenComponents.git|label=Go to Git Repository}}
{{#widget:Models|img=/Special:Filepath/File:BaseApp_image.png|title=BaseApp|description=A model extracted from larger models used in various projects with certain functions ready to go.|downloadLink=https://learn.mdriven.net/images/d/de/BaseApp.zip|label=Download this pattern}}
{{#widget:Models|img=/Special:Filepath/File:Asp.Net_Identity_package_image.png|title=Asp.Net Identity package|description=Use this pattern for Turnkey login support.|downloadLink=https://learn.mdriven.net/images/b/b3/AspNetIdentity.zip|label=Download this pattern}}
<html>
</div>
</div>
</section>
  </section>
<hr class="section-divider" />
  <!-- Section for Extensions -->
  <section id="final-model">
        <h2>Extensions</h2>
<div><span style="color: black; font-size: 16px; word-wrap: break-word">Ready-made solutions used by importing into an existing model. </span><a href="#" style="color: #1A50AD; font-size: 16px; font-weight: 500; text-decoration: underline; word-wrap: break-word"> <a href='https://wiki.mdriven.net/Documentation:Model_Examples_Old'> How to merge modlr files?</a></div>
    <div class="card-container">
</html>
{{#widget:Models|img=/Special:Filepath/File:2020-05-31_12h01_07.png|title=Consume and Purchase GetPaid#1|description=This model extends your system with the ability to charge the end-user for services you provide.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/ChargeEndUserViaMDrivenPortalService.modlr|label=Download this extension}}
{{#widget:Models|img=/Special:Filepath/File:2020-07-20_12h48_44.png|title=PayPal - Checkout GetPaid#2|description=Integrate PayPal as an alternative method to get paid by users.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/PayPalCheckout.modlr|label=Download this extension}}
{{#widget:Models|img=/Special:Filepath/File:2020-06-22_18h49_08.png|title=Theme Builder - Build Themes in Runtime|description=Set CSS variables to influence the colors and sizes of the UI.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/ThemeBuilder.modlr|label=Download this extension}}
{{#widget:Models|img=/Special:Filepath/File:OutgoingEmailQueue-model.png|title=Outgoing Email Queue|description=This is a model pattern that adds an outgoing email queue to the standard base model.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/OutgoingEmailQueue.modlr|label=Download this extension}}
{{#widget:Models|img=/Special:Filepath/File:Calender_model_diagram.png|title=Calendar Model for Linking Things to Dates, Weeks, Months, and Years|description=This model implements classes that make aggregation (for statistics, for example) easy.|downloadLink=https://learn.mdriven.net/Special:Redirect/file/CalendarPackage.modlr|label=Download this extension}}
{{#widget:Models|img=/Special:Filepath/File:ComplaintTrackerStartScreen.png|title=Store Complaint Handling|description=The complete app, model, and example data for a clothing shop, to help staff handle customer complaints professionally.|downloadLink=https://learn.mdriven.net/images/5/50/StoreComplaintHandling.zip|label=Download this extension}}
{{#widget:Models|img=/Special:Filepath/File:2017-08-26_17h45_56.png|title=Turnkey Sample SoftConflict|description=A small app that helps you be constructive about issues in your daily life.|downloadLink=https://learn.mdriven.net/images/a/ac/DatabaseCompact.zip|label=Download this extension}}
{{#widget:Models|img=/Special:Filepath/File:2017-08-07_22h03_55.png|title=Turnkey Sample Board Map Balls Gantt|description=This sample is a bit of a playground for html5 component development that jacks into the Turnkey.|downloadLink=https://learn.mdriven.net/Documentation:Turnkey_sample_Board_Map_Balls_Gantt|label=Go to this page}}
 
 


<!-- Section for Complete Models -->
<html>
<section id="another-model">
      <h2 style="margin-left:300px;">Complete Models</h2>
  <div class="card-container" style="margin-left:300px;">
    <!-- Card 1 -->
    <div class="cards">
      <img src="https://via.placeholder.com/301x175" alt="Placeholder">
      <div class="contentss">
        <div class="title">Base App</div>
        <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
        <div class="download-link">
          <div class="download-indicator"></div>
          <div>Download .zip</div>
        </div>
      </div>
     </div>
     </div>
    <!-- Card 2 -->
    <!-- Repeat the structure for other cards as needed -->
    <!-- ... -->
    <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
  </div>
</div>
</div>
<!-- Section for Complete Models -->
<section id="final-model">
      <h2 style="margin-left:300px;">Complete Models</h2>
  <div class="card-container" style="margin-left:300px;">
    <!-- Card 1 -->
    <div class="cards">
      <img src="https://via.placeholder.com/301x175" alt="Placeholder">
      <div class="contentss">
        <div class="title">Base App</div>
        <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
        <div class="download-link">
          <div class="download-indicator"></div>
          <div>Download .zip</div>
        </div>
      </div>
     </div>
     </div>
    <!-- Card 2 -->
  </section>
    <!-- Repeat the structure for other cards as needed -->
</main>
    <!-- ... -->
    <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Test</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
      <div class="cards">
        <img src="https://via.placeholder.com/301x175" alt="Placeholder">
        <div class="contentss">
          <div class="title">Base App</div>
          <div class="description">You can use this as a starting point or you can merge it with most of the other examples and template models.</div>
          <div class="download-link">
            <div class="download-indicator"></div>
            <div>Download .zip</div>
          </div>
        </div>
      </div>
  </div>
</div>
</div>
<script>
  <script>
function searchCards() {
  function searchCards() {
  var input, filter, cards, title, i, txtValue;
    var input, filter, cards, title, i, txtValue;
  input = document.getElementById("searchBox");
    input = document.getElementById("searchBox");
  filter = input.value.toUpperCase();
    filter = input.value.toUpperCase();
  cards = document.getElementsByClassName("cards");
    cards = document.getElementsByClassName("cards");
 
 
  for (i = 0; i < cards.length; i++) {
    for (i = 0; i < cards.length; i++) {
    title = cards[i].getElementsByClassName("title")[0];
      title = cards[i].getElementsByClassName("title")[0];
    if (title) {
      if (title) {
      txtValue = title.textContent || title.innerText;
        txtValue = title.textContent || title.innerText;
      if (txtValue.toUpperCase().indexOf(filter) > -1) {
        if (txtValue.toUpperCase().indexOf(filter) > -1) {
        cards[i].style.display = "";
          cards[i].style.display = "";
      } else {
        } else {
        cards[i].style.display = "none";
          cards[i].style.display = "none";
       }
        }
     }      
       }    
     }
   }
   }
}
  </script>
</script>
  <script>
<script>
  // JavaScript to scroll to the section smoothly when a sidebar link is clicked
// JavaScript to scroll to the section smoothly when a sidebar link is clicked
  document.addEventListener('DOMContentLoaded', (event) => {
document.addEventListener('DOMContentLoaded', (event) => {
    document.querySelectorAll('.sidebar a').forEach(link => {
  document.querySelectorAll('.sidebar a').forEach(link => {
      link.addEventListener('click', function(e) {
    link.addEventListener('click', function(e) {
        e.preventDefault();
      e.preventDefault();
        const targetId = this.getAttribute('href');
      const targetId = this.getAttribute('href');
        const targetSection = document.querySelector(targetId);
      const targetSection = document.querySelector(targetId);
        if (targetSection) {
      if (targetSection) {
          targetSection.scrollIntoView({ behavior: 'smooth', block: 'start' });
        targetSection.scrollIntoView({ behavior: 'smooth', block: 'start' });
        }
       }
       });
     });
     });
   });
   });
});
  </script>
</script>
  <script>
<script>
 
  document.addEventListener('DOMContentLoaded', (event) => {
document.addEventListener('DOMContentLoaded', (event) => {
    document.querySelectorAll('.sidebar a').forEach(link => {
  document.querySelectorAll('.sidebar a').forEach(link => {
      link.addEventListener('click', function(e) {
    link.addEventListener('click', function(e) {
        e.preventDefault();
      e.preventDefault();
        const targetId = this.getAttribute('href');
      const targetId = this.getAttribute('href');
        const targetSection = document.querySelector(targetId);
      const targetSection = document.querySelector(targetId);
        if (targetSection) {
      if (targetSection) {
          targetSection.scrollIntoView({ behavior: 'smooth', block: 'start' });
        targetSection.scrollIntoView({ behavior: 'smooth', block: 'start' });
        }
       }
       });
     });
     });
   });
   });
});
  </script>
</script>
  <script>
<script>
  document.addEventListener('DOMContentLoaded', (event) => {
document.addEventListener('DOMContentLoaded', (event) => {
    const svgMarkup = `<svg xmlns="http://www.w3.org/2000/svg" width="4" height="16" viewBox="0 0 4 16" fill="none">
  const svgMarkup = `<svg xmlns="http://www.w3.org/2000/svg" width="4" height="16" viewBox="0 0 4 16" fill="none">
      <path d="M0 0C2.20914 0 4 1.79086 4 4L4 12C4 14.2091 2.20914 16 0 16L0 0Z" fill="#1A50AD"/>
    <path d="M0 0C2.20914 0 4 1.79086 4 4L4 12C4 14.2091 2.20914 16 0 16L0 0Z" fill="#1A50AD"/>
    </svg>`;
  </svg>`;
    // Function to create a new SVG element
    const createSvgElement = (htmlString) => {
      const div = document.createElement('div');
      div.innerHTML = htmlString.trim();
      return div.firstChild;
    };
    // Function to update active link style and SVG
    const updateActiveLink = (targetId) => {
      document.querySelectorAll('.sidebar a').forEach(link => {
        if (link.getAttribute('href') === targetId) {
          link.classList.add('active');
          // Insert SVG for active link
          link.prepend(createSvgElement(svgMarkup));
        } else {
          link.classList.remove('active');
          // Remove SVG for non-active links
          if (link.querySelector('svg')) {
            link.removeChild(link.querySelector('svg'));
          }
        }
      });
    };


  // Function to create a new SVG element
updateActiveLink('#complete-models');
  const createSvgElement = (htmlString) => {
    const div = document.createElement('div');
    div.innerHTML = htmlString.trim();
    return div.firstChild;
  };
 
  // Function to update active link style and SVG
  const updateActiveLink = (targetId) => {
     document.querySelectorAll('.sidebar a').forEach(link => {
     document.querySelectorAll('.sidebar a').forEach(link => {
       if (link.getAttribute('href') === targetId) {
       link.addEventListener('click', function(e) {
         link.classList.add('active');
         e.preventDefault();
         // Insert SVG for active link
        const targetId = this.getAttribute('href');
        link.prepend(createSvgElement(svgMarkup));
         updateActiveLink(targetId);
      } else {
         const targetSection = document.querySelector(targetId);
         link.classList.remove('active');
         if (targetSection) {
        // Remove SVG for non-active links
           targetSection.scrollIntoView({ behavior: 'smooth', block: 'start' });
         if (link.querySelector('svg')) {
           link.removeChild(link.querySelector('svg'));
         }
         }
       }
       });
    });
  };
 
  document.querySelectorAll('.sidebar a').forEach(link => {
    link.addEventListener('click', function(e) {
      e.preventDefault();
      const targetId = this.getAttribute('href');
      updateActiveLink(targetId);
      const targetSection = document.querySelector(targetId);
      if (targetSection) {
        targetSection.scrollIntoView({ behavior: 'smooth', block: 'start' });
      }
     });
     });
   });
   });
});
  </script>
</script>
  </html>
 
{{Edited|July|12|2024}}
</html>
{{Class|scroll}}

Latest revision as of 14:58, 2 April 2024

Model examples
BROWSE MODEL SAMPLES
Get started with MDriven sample models and packages. Explore and select what you want to build.

Complete Models

Use ready-made "complete system" (model+data) to apply to an existing turnkey site. How to merge modlr files?
Placeholder
Gantt Chart Interactive
Use this when you need to show and interact with data in a timeline.
Download Modlr file
Placeholder
A Trello-like Board With Cards You Can Move Between Lists
Move cards between lists, click cards, add new cards and more.
Download Modlr file
Placeholder
Markup Editor TinyMCE
Lets your users produce rich HTML text.
Download Modlr file
Placeholder
SVG - Move boxes around
Objects represented by SVG graphics that react to mouse events so that they can be moved around and saved.
Download Modlr file
Placeholder
Google Maps to Show and Update Positions
Place a marker on a Google map, track the setting of the map, and move the marker.
Download Modlr file


Patterns

Packages primarily used by importing into an existing model. How to merge modlr files?
Placeholder
SysUserAuthentication - important architectural pattern
This example adds the SysSingleton and SysUser classes needed to enable login and authentication in Turnkey systems.
Download this pattern
Placeholder
Password Reset Sample - Architectural Pattern
Add this functionality to your model and this frees you to integrate and adapt it as needed.
Download this pattern
Placeholder
SysAsyncTicket - Important Architectural Pattern
A model pattern you can easily add to your model, backed by recent MDrivenServers.
Go to the SysAsyncTicket page
Placeholder
Localization and Translation - Architectural Pattern
MDriven systems can adhere to a model pattern and use that to store translations to all texts in actions and ViewModels.
Download this pattern
Placeholder
SysTurnkeyTraceLog
Add a class following this pattern if you need to track what users are up to in your Turnkey app.
Go to Git Repository
Placeholder
BaseApp
A model extracted from larger models used in various projects with certain functions ready to go.
Download this pattern
Placeholder
Asp.Net Identity package
Use this pattern for Turnkey login support.
Download this pattern


Extensions

Ready-made solutions used by importing into an existing model. How to merge modlr files?
Placeholder
Consume and Purchase GetPaid#1
This model extends your system with the ability to charge the end-user for services you provide.
Download this extension
Placeholder
PayPal - Checkout GetPaid#2
Integrate PayPal as an alternative method to get paid by users.
Download this extension
Placeholder
Theme Builder - Build Themes in Runtime
Set CSS variables to influence the colors and sizes of the UI.
Download this extension
Placeholder
Outgoing Email Queue
This is a model pattern that adds an outgoing email queue to the standard base model.
Download this extension
Placeholder
Calendar Model for Linking Things to Dates, Weeks, Months, and Years
This model implements classes that make aggregation (for statistics, for example) easy.
Download this extension
Placeholder
Store Complaint Handling
The complete app, model, and example data for a clothing shop, to help staff handle customer complaints professionally.
Download this extension
Placeholder
Turnkey Sample SoftConflict
A small app that helps you be constructive about issues in your daily life.
Download this extension
Placeholder
Turnkey Sample Board Map Balls Gantt
This sample is a bit of a playground for html5 component development that jacks into the Turnkey.
Go to this page