appscms-tools-theme 5.1.8 → 5.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (124) hide show
  1. checksums.yaml +4 -4
  2. data/_data/.DS_Store +0 -0
  3. data/_data/aitools/en/ai-article-writer.json +184 -0
  4. data/_data/aitools/en/all-in-one-social-post.json +217 -0
  5. data/_data/aitools/en/amazon-product-bullet-points-generator.json +224 -0
  6. data/_data/aitools/en/amazon-product-description-generator.json +237 -0
  7. data/_data/aitools/en/blog-conclusion-generator.json +253 -0
  8. data/_data/aitools/en/blog-content-calendar.json +232 -0
  9. data/_data/aitools/en/blog-introduction-generator.json +246 -0
  10. data/_data/aitools/en/blog-outline-generator.json +232 -0
  11. data/_data/aitools/en/blog-section-generator.json +253 -0
  12. data/_data/aitools/en/blog-title-generator.json +232 -0
  13. data/_data/aitools/en/blog-topic-ideas.json +232 -0
  14. data/_data/aitools/en/brand-name-generator.json +215 -0
  15. data/_data/aitools/en/caption-generator.json +271 -0
  16. data/_data/aitools/en/engagement-post-generator.json +251 -0
  17. data/_data/aitools/en/facebook-post.json +232 -0
  18. data/_data/aitools/en/hidden-fact-finder.json +232 -0
  19. data/_data/aitools/en/human-written-blog-post.json +232 -0
  20. data/_data/aitools/en/instagram-bio-generator.json +246 -0
  21. data/_data/aitools/en/instagram-caption.json +232 -0
  22. data/_data/aitools/en/instagram-carousel.json +250 -0
  23. data/_data/aitools/en/instagram-hashtag-generator.json +246 -0
  24. data/_data/aitools/en/instagram-name-generator.json +239 -0
  25. data/_data/aitools/en/instagram-threads-generator.json +239 -0
  26. data/_data/aitools/en/interactive-content-creator.json +252 -0
  27. data/_data/aitools/en/linkedin-hashtag-generator.json +239 -0
  28. data/_data/aitools/en/linkedin-post.json +232 -0
  29. data/_data/aitools/en/motivational-posts.json +239 -0
  30. data/_data/aitools/en/pinterest-pin.json +217 -0
  31. data/_data/aitools/en/platform-specific-content-generator.json +246 -0
  32. data/_data/aitools/en/product-description.json +222 -0
  33. data/_data/aitools/en/quick-article-writer.json +253 -0
  34. data/_data/aitools/en/replies-for-facebook.json +239 -0
  35. data/_data/aitools/en/replies-for-instagram.json +239 -0
  36. data/_data/aitools/en/replies-for-linkedin.json +239 -0
  37. data/_data/aitools/en/replies-for-twitter.json +239 -0
  38. data/_data/aitools/en/rewrite-article-with-keywords.json +246 -0
  39. data/_data/aitools/en/script-for-instagram-reel.json +246 -0
  40. data/_data/aitools/en/script-for-tiktok-video.json +246 -0
  41. data/_data/aitools/en/seo-optimized-blog-post.json +239 -0
  42. data/_data/aitools/en/snapchat-caption-maker.json +245 -0
  43. data/_data/aitools/en/social-media-bio-creator.json +274 -0
  44. data/_data/aitools/en/social-media-bio-generator.json +246 -0
  45. data/_data/aitools/en/social-media-calendar.json +250 -0
  46. data/_data/aitools/en/tiktok-caption.json +232 -0
  47. data/_data/aitools/en/tiktok-username-generator.json +239 -0
  48. data/_data/aitools/en/twitter-poll-generator.json +250 -0
  49. data/_data/aitools/en/twitter-post.json +272 -0
  50. data/_data/contenttool/en/features.json +217 -10
  51. data/_includes/.DS_Store +0 -0
  52. data/_includes/appscms/.DS_Store +0 -0
  53. data/_includes/appscms/customblog/pageRelatedPosts.html +1 -1
  54. data/_layouts/appscms-feature.html +1 -1
  55. data/_layouts/content-tool-ai copy 2.html +6611 -0
  56. data/_layouts/content-tool-ai.html +305 -44
  57. data/assets/.DS_Store +0 -0
  58. data/assets/css/content-tool-ai.css +815 -11
  59. metadata +50 -67
  60. data/assets/js/.DS_Store +0 -0
  61. data/assets/js/TopScroll.js +0 -8
  62. data/assets/js/adBlocker.js +0 -68
  63. data/assets/js/ads.js +0 -8
  64. data/assets/js/append-div.js +0 -10
  65. data/assets/js/appscms-infographics.js +0 -0
  66. data/assets/js/appscms-login.js +0 -447
  67. data/assets/js/appscms-search-home1.js +0 -136
  68. data/assets/js/appscms-search.js +0 -133
  69. data/assets/js/appscms-theme.js +0 -459
  70. data/assets/js/batch.js +0 -219
  71. data/assets/js/blog-topic-ideas.js +0 -57
  72. data/assets/js/calculator-tooltip.js +0 -3
  73. data/assets/js/devtools.js +0 -82
  74. data/assets/js/face-api.js +0 -38064
  75. data/assets/js/face-detection.js +0 -303
  76. data/assets/js/faceSystem.js +0 -0
  77. data/assets/js/featureResult.js +0 -48
  78. data/assets/js/frame.js +0 -264
  79. data/assets/js/googledrive.js +0 -158
  80. data/assets/js/homeResult.js +0 -37
  81. data/assets/js/human-written-blog-post.js +0 -57
  82. data/assets/js/instagram-caption.js +0 -57
  83. data/assets/js/instagram-hashtag-generator.js +0 -10
  84. data/assets/js/instagram-name-generator.js +0 -61
  85. data/assets/js/manifest.json +0 -17
  86. data/assets/js/models/age_gender_model-shard1 +0 -0
  87. data/assets/js/models/age_gender_model-weights_manifest.json +0 -1
  88. data/assets/js/models/face_expression_model-shard1 +0 -0
  89. data/assets/js/models/face_expression_model-weights_manifest.json +0 -1
  90. data/assets/js/models/face_landmark_68_model-shard1 +0 -0
  91. data/assets/js/models/face_landmark_68_model-weights_manifest.json +0 -1
  92. data/assets/js/models/face_landmark_68_tiny_model-shard1 +0 -0
  93. data/assets/js/models/face_landmark_68_tiny_model-weights_manifest.json +0 -1
  94. data/assets/js/models/face_recognition_model-shard1 +0 -0
  95. data/assets/js/models/face_recognition_model-shard2 +0 -6
  96. data/assets/js/models/face_recognition_model-weights_manifest.json +0 -1
  97. data/assets/js/models/mtcnn_model-shard1 +0 -0
  98. data/assets/js/models/mtcnn_model-weights_manifest.json +0 -1
  99. data/assets/js/models/ssd_mobilenetv1_model-shard1 +0 -0
  100. data/assets/js/models/ssd_mobilenetv1_model-shard2 +8 -137
  101. data/assets/js/models/ssd_mobilenetv1_model-weights_manifest.json +0 -1
  102. data/assets/js/models/tiny_face_detector_model-shard1 +0 -0
  103. data/assets/js/models/tiny_face_detector_model-weights_manifest.json +0 -1
  104. data/assets/js/multiselect.js +0 -185
  105. data/assets/js/partytown/debug/partytown-atomics.js +0 -929
  106. data/assets/js/partytown/debug/partytown-media.js +0 -374
  107. data/assets/js/partytown/debug/partytown-sandbox-sw.js +0 -920
  108. data/assets/js/partytown/debug/partytown-sw.js +0 -59
  109. data/assets/js/partytown/debug/partytown-ww-atomics.js +0 -2699
  110. data/assets/js/partytown/debug/partytown-ww-sw.js +0 -2691
  111. data/assets/js/partytown/debug/partytown.js +0 -114
  112. data/assets/js/partytown/partytown-atomics.js +0 -600
  113. data/assets/js/partytown/partytown-media.js +0 -2
  114. data/assets/js/partytown/partytown-sw.js +0 -50
  115. data/assets/js/perspective.min.js +0 -182
  116. data/assets/js/photo-effects.json +0 -85
  117. data/assets/js/redirectResult.js +0 -10
  118. data/assets/js/sharePage.js +0 -65
  119. data/assets/js/testing-batch.js +0 -39
  120. data/assets/js/theme.js +0 -104
  121. data/assets/js/usageTracking.js +0 -143
  122. data/assets/js/usageTrackingEvents.js +0 -6
  123. data/assets/js/userUsageCount.js +0 -0
  124. data/assets/js/webvitals.js +0 -5
@@ -22,7 +22,211 @@ assign boxColor = site.data[page.folderName][page.lang][page.fileName].color -%}
22
22
  <img src="/assets/images/content-tool-logo.png" alt="" />
23
23
  </a>
24
24
  </div>
25
- <button class="btn btn-primary btn-login">Login</button>
25
+ {%- if site.authentication -%}
26
+ <button class="login-modal-button open-modal-btn login-btn" style="width: 100px; padding: 5px 10px;" type="button" data-bs-toggle="offcanvas" data-bs-target="#offcanvasRight" aria-controls="offcanvasRight">Login</button>
27
+ <div class="user-profile-header">
28
+
29
+ <div class="profile-button" id="profileButton">
30
+
31
+
32
+ </div>
33
+ </div>
34
+
35
+ <div class="user-modal" id="userModal">
36
+ <div class="modal-item">
37
+ <div class="profile-user-avatar">GI</div>
38
+ <div class="user-info">
39
+ <div class="logged-in-username">Gill</div>
40
+ <p class="logged-in-user-email">itsrammoudgill@gmail.com</p>
41
+ </div>
42
+
43
+ </div>
44
+
45
+ <div class="modal-item">
46
+ <div class="item-icon"><svg height="20" width="20" viewBox="0 0 24 24" id="Layer_1" data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" fill="#000000"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"><defs><style>.cls-1{fill:none;stroke:#020202;stroke-miterlimit:10;stroke-width:1.91px;}</style></defs><circle class="cls-1" cx="12" cy="7.25" r="5.73"></circle><path class="cls-1" d="M1.5,23.48l.37-2.05A10.3,10.3,0,0,1,12,13h0a10.3,10.3,0,0,1,10.13,8.45l.37,2.05"></path></g></svg></div>
47
+ <div class="item-text">
48
+ <a href="/profile">Account</a> </div>
49
+ <div class="item-arrow"><svg viewBox="-4.5 0 20 20" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="#000000"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <title>arrow_right [#336]</title> <desc>Created with Sketch.</desc> <defs> </defs> <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"> <g id="Dribbble-Light-Preview" transform="translate(-305.000000, -6679.000000)" fill="#000000"> <g id="icons" transform="translate(56.000000, 160.000000)"> <path d="M249.365851,6538.70769 L249.365851,6538.70769 C249.770764,6539.09744 250.426289,6539.09744 250.830166,6538.70769 L259.393407,6530.44413 C260.202198,6529.66364 260.202198,6528.39747 259.393407,6527.61699 L250.768031,6519.29246 C250.367261,6518.90671 249.720021,6518.90172 249.314072,6519.28247 L249.314072,6519.28247 C248.899839,6519.67121 248.894661,6520.31179 249.302681,6520.70653 L257.196934,6528.32352 C257.601847,6528.71426 257.601847,6529.34685 257.196934,6529.73759 L249.365851,6537.29462 C248.960938,6537.68437 248.960938,6538.31795 249.365851,6538.70769" id="arrow_right-[#336]"> </path> </g> </g> </g> </g></svg></div>
50
+ </div>
51
+
52
+ <div class="modal-item">
53
+ <div class="item-icon"><svg height="20" width="20" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <g id="Warning / Help"> <path id="Vector" d="M8.19531 8.76498C8.42304 8.06326 8.84053 7.43829 9.40137 6.95899C9.96221 6.47968 10.6444 6.16501 11.373 6.0494C12.1017 5.9338 12.8486 6.02202 13.5303 6.3042C14.2119 6.58637 14.8016 7.05166 15.2354 7.64844C15.6691 8.24521 15.9295 8.95008 15.9875 9.68554C16.0455 10.421 15.8985 11.1581 15.5636 11.8154C15.2287 12.4728 14.7192 13.0251 14.0901 13.4106C13.4611 13.7961 12.7377 14.0002 12 14.0002V14.9998M12.0498 19V19.1L11.9502 19.1002V19H12.0498Z" stroke="#000000" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"></path> </g> </g></svg></div>
54
+ <div class="item-text">
55
+ <a href="/contact">Contact</a>
56
+ </div>
57
+ <div class="item-arrow"><svg viewBox="-4.5 0 20 20" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="#000000"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <title>arrow_right [#336]</title> <desc>Created with Sketch.</desc> <defs> </defs> <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"> <g id="Dribbble-Light-Preview" transform="translate(-305.000000, -6679.000000)" fill="#000000"> <g id="icons" transform="translate(56.000000, 160.000000)"> <path d="M249.365851,6538.70769 L249.365851,6538.70769 C249.770764,6539.09744 250.426289,6539.09744 250.830166,6538.70769 L259.393407,6530.44413 C260.202198,6529.66364 260.202198,6528.39747 259.393407,6527.61699 L250.768031,6519.29246 C250.367261,6518.90671 249.720021,6518.90172 249.314072,6519.28247 L249.314072,6519.28247 C248.899839,6519.67121 248.894661,6520.31179 249.302681,6520.70653 L257.196934,6528.32352 C257.601847,6528.71426 257.601847,6529.34685 257.196934,6529.73759 L249.365851,6537.29462 C248.960938,6537.68437 248.960938,6538.31795 249.365851,6538.70769" id="arrow_right-[#336]"> </path> </g> </g> </g> </g></svg></div>
58
+ </div>
59
+
60
+ <div class="modal-item" id="logoutBtn">
61
+ <div class="item-icon"><svg height="20" width="20" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <path d="M12 20C7.58172 20 4 16.4183 4 12C4 7.58172 7.58172 4 12 4" stroke="#1C274C" stroke-width="1.5" stroke-linecap="round"></path> <path d="M10 12H20M20 12L17 9M20 12L17 15" stroke="#1C274C" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"></path> </g></svg></div>
62
+ <div class="item-text">Log out</div>
63
+ <div class="item-arrow"><svg viewBox="-4.5 0 20 20" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="#000000"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <title>arrow_right [#336]</title> <desc>Created with Sketch.</desc> <defs> </defs> <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"> <g id="Dribbble-Light-Preview" transform="translate(-305.000000, -6679.000000)" fill="#000000"> <g id="icons" transform="translate(56.000000, 160.000000)"> <path d="M249.365851,6538.70769 L249.365851,6538.70769 C249.770764,6539.09744 250.426289,6539.09744 250.830166,6538.70769 L259.393407,6530.44413 C260.202198,6529.66364 260.202198,6528.39747 259.393407,6527.61699 L250.768031,6519.29246 C250.367261,6518.90671 249.720021,6518.90172 249.314072,6519.28247 L249.314072,6519.28247 C248.899839,6519.67121 248.894661,6520.31179 249.302681,6520.70653 L257.196934,6528.32352 C257.601847,6528.71426 257.601847,6529.34685 257.196934,6529.73759 L249.365851,6537.29462 C248.960938,6537.68437 248.960938,6538.31795 249.365851,6538.70769" id="arrow_right-[#336]"> </path> </g> </g> </g> </g></svg></div>
64
+ </div>
65
+ </div>
66
+ <div class="side-modal-overlay" id="modalOverlay"></div>
67
+
68
+ <div class="side-modal" id="sideModal">
69
+ <div class="modal-header">
70
+ <div>
71
+
72
+ {%- if siteData.navbarBrandLogoSvg -%}
73
+ <a href="/" aria-label="home-page"> {{siteData.navbarBrandLogoSvg}} </a>
74
+ {%- elsif siteData.navbarBrandText -%}
75
+ <span> {{siteData.navbarBrandText}}
76
+ {%- else -%}
77
+ {%- endif -%}
78
+ </div>
79
+ <button class="close-modal-btn">&times;</button>
80
+ </div>
81
+ <div class="side-modal-content">
82
+ <div class="modal-body d-flex justify-content-center">
83
+ <div class="user-avatar" id="userAvatar" style="display: none">GI</div>
84
+ <div class="auth-container" id="authContainer">
85
+ <div id="loginForm">
86
+ <h1>Log in</h1>
87
+ <h2>
88
+ Don't have an account? <a href="#" id="showSignup">Create account</a>
89
+ </h2>
90
+
91
+ <div class="auth-forms">
92
+ <button class="social-btn google-btn" id="googleLogin">
93
+ <svg viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <path d="M30.0014 16.3109C30.0014 15.1598 29.9061 14.3198 29.6998 13.4487H16.2871V18.6442H24.1601C24.0014 19.9354 23.1442 21.8798 21.2394 23.1864L21.2127 23.3604L25.4536 26.58L25.7474 26.6087C28.4458 24.1665 30.0014 20.5731 30.0014 16.3109Z" fill="#4285F4"></path> <path d="M16.2863 29.9998C20.1434 29.9998 23.3814 28.7553 25.7466 26.6086L21.2386 23.1863C20.0323 24.0108 18.4132 24.5863 16.2863 24.5863C12.5086 24.5863 9.30225 22.1441 8.15929 18.7686L7.99176 18.7825L3.58208 22.127L3.52441 22.2841C5.87359 26.8574 10.699 29.9998 16.2863 29.9998Z" fill="#34A853"></path> <path d="M8.15964 18.769C7.85806 17.8979 7.68352 16.9645 7.68352 16.0001C7.68352 15.0356 7.85806 14.1023 8.14377 13.2312L8.13578 13.0456L3.67083 9.64746L3.52475 9.71556C2.55654 11.6134 2.00098 13.7445 2.00098 16.0001C2.00098 18.2556 2.55654 20.3867 3.52475 22.2845L8.15964 18.769Z" fill="#FBBC05"></path> <path d="M16.2864 7.4133C18.9689 7.4133 20.7784 8.54885 21.8102 9.4978L25.8419 5.64C23.3658 3.38445 20.1435 2 16.2864 2C10.699 2 5.8736 5.1422 3.52441 9.71549L8.14345 13.2311C9.30229 9.85555 12.5086 7.4133 16.2864 7.4133Z" fill="#EB4335"></path> </g></svg>
94
+ Continue with Google
95
+ </button>
96
+ <button class="social-btn facebook-btn d-none" id="facebookLogin">
97
+ <span class="icon facebook-icon"></span>
98
+ Continue with Facebook
99
+ </button>
100
+ <!-- Add this inside your auth-forms div in both login and signup sections -->
101
+ <button class="social-btn twitter-btn d-none" id="twitterLogin">
102
+ <svg
103
+ viewBox="0 0 24 24"
104
+ width="24"
105
+ height="24"
106
+ style="margin-right: 10px"
107
+ >
108
+ <path
109
+ fill="white"
110
+ d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"
111
+ />
112
+ </svg>
113
+ Continue with X
114
+ </button>
115
+
116
+ <div class="or-divider">Or</div>
117
+
118
+ <form id="emailLoginForm">
119
+ <div class="input-group">
120
+ <span class="icon email-icon"></span>
121
+ <input
122
+ type="email"
123
+ id="loginEmail"
124
+ placeholder="Email"
125
+ required
126
+ />
127
+ </div>
128
+ <div class="input-group">
129
+ <span class="icon password-icon"></span>
130
+ <input
131
+ type="password"
132
+ id="loginPassword"
133
+ placeholder="Password"
134
+ required
135
+ />
136
+ <span
137
+ class="password-toggle icon eye-icon"
138
+ id="toggleLoginPassword"
139
+ ></span>
140
+ </div>
141
+ <button type="submit" class="login-btn">Log in</button>
142
+ </form>
143
+
144
+ <div class="forgot-password">
145
+ <a href="#" id="forgotPassword">Forgot your password?</a>
146
+ </div>
147
+ </div>
148
+ </div>
149
+
150
+ <!-- Forgot Password Form -->
151
+ <div id="forgotPasswordForm">
152
+ <div class="back-btn" id="backToLogin">
153
+ <span class="back-icon">←</span>
154
+ Back to login
155
+ </div>
156
+
157
+ <h1>Reset password</h1>
158
+ <h2>
159
+ Enter your email address and we'll send you a link to reset your
160
+ password
161
+ </h2>
162
+
163
+ <form id="resetPasswordForm">
164
+ <div class="input-group">
165
+ <span class="icon email-icon"></span>
166
+ <input type="email" id="resetEmail" placeholder="Email" required />
167
+ </div>
168
+ <button type="submit" class="login-btn">Send reset link</button>
169
+ </form>
170
+
171
+ <div class="reset-success" id="resetSuccess">
172
+ <div class="success-icon">✓</div>
173
+ <h3>Reset link sent</h3>
174
+ <p>Check your email for instructions to reset your password</p>
175
+ </div>
176
+ </div>
177
+
178
+ <!-- Sign Up Form -->
179
+ <div id="signupForm" style="display: none">
180
+ <h1>Create your account</h1>
181
+ <h2>Already have an account? <a href="#" id="showLogin">Log in</a></h2>
182
+
183
+ <div class="auth-forms">
184
+ <button class="social-btn google-btn" id="googleSignup">
185
+ <svg viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"> <path d="M30.0014 16.3109C30.0014 15.1598 29.9061 14.3198 29.6998 13.4487H16.2871V18.6442H24.1601C24.0014 19.9354 23.1442 21.8798 21.2394 23.1864L21.2127 23.3604L25.4536 26.58L25.7474 26.6087C28.4458 24.1665 30.0014 20.5731 30.0014 16.3109Z" fill="#4285F4"></path> <path d="M16.2863 29.9998C20.1434 29.9998 23.3814 28.7553 25.7466 26.6086L21.2386 23.1863C20.0323 24.0108 18.4132 24.5863 16.2863 24.5863C12.5086 24.5863 9.30225 22.1441 8.15929 18.7686L7.99176 18.7825L3.58208 22.127L3.52441 22.2841C5.87359 26.8574 10.699 29.9998 16.2863 29.9998Z" fill="#34A853"></path> <path d="M8.15964 18.769C7.85806 17.8979 7.68352 16.9645 7.68352 16.0001C7.68352 15.0356 7.85806 14.1023 8.14377 13.2312L8.13578 13.0456L3.67083 9.64746L3.52475 9.71556C2.55654 11.6134 2.00098 13.7445 2.00098 16.0001C2.00098 18.2556 2.55654 20.3867 3.52475 22.2845L8.15964 18.769Z" fill="#FBBC05"></path> <path d="M16.2864 7.4133C18.9689 7.4133 20.7784 8.54885 21.8102 9.4978L25.8419 5.64C23.3658 3.38445 20.1435 2 16.2864 2C10.699 2 5.8736 5.1422 3.52441 9.71549L8.14345 13.2311C9.30229 9.85555 12.5086 7.4133 16.2864 7.4133Z" fill="#EB4335"></path> </g></svg>
186
+ Continue with Google
187
+ </button>
188
+
189
+ <div class="or-divider">Or</div>
190
+
191
+ <form id="emailSignupForm">
192
+ <div class="input-group">
193
+ <span class="icon email-icon"></span>
194
+ <input
195
+ type="email"
196
+ id="signupEmail"
197
+ placeholder="Email"
198
+ required
199
+ />
200
+ </div>
201
+ <div class="input-group">
202
+ <span class="icon password-icon"></span>
203
+ <input
204
+ type="password"
205
+ id="signupPassword"
206
+ placeholder="Password"
207
+ required
208
+ />
209
+ <span
210
+ class="password-toggle icon eye-icon"
211
+ id="toggleSignupPassword"
212
+ ></span>
213
+ </div>
214
+ <button type="submit" class="login-btn">Create account</button>
215
+ </form>
216
+
217
+ <p style="font-size: 14px; color: #777; text-align: center">
218
+ By creating an account, you agree to our
219
+ <a href="#">Privacy Policy</a> and our
220
+ <a href="#">Terms & Conditions.</a>
221
+ </p>
222
+ </div>
223
+ </div>
224
+
225
+ </div><div class="user-avatar" id="userAvatar" style="display: none"></div>
226
+ </div>
227
+ </div>
228
+ </div>
229
+ {%- endif -%}
26
230
  </div>
27
231
  </nav>
28
232
 
@@ -78,60 +282,97 @@ assign boxColor = site.data[page.folderName][page.lang][page.fileName].color -%}
78
282
  </span>
79
283
  </div>
80
284
  <div class="submenu expanded" id="{{item.id}}">
81
- {%- for i in item.features -%}
82
- <div class="submenu-item">
83
- <img src="{{i.img}}" alt="" />
84
- <a href="{{i.url}}"> <span>{{i.name}}</span></a>
85
- </div>
86
- {%- endfor -%}
87
- </div>
285
+ {%- for i in item.features -%}
286
+ <div class="submenu-item {% if page.permalink == i.url %}url-active{% endif %}">
287
+ <img src="{{i.img}}" alt="" />
288
+ <a href="{{i.url}}"><span>{{i.name}}</span></a>
289
+ </div>
290
+ {%- endfor -%}
291
+ </div>
292
+
88
293
  {%- endfor -%}
89
294
  </div>
90
295
  </div>
91
296
  </div>
297
+ <style>
298
+ .custom-switch .custom-control-input:checked ~ .custom-control-label::before {
299
+ background-color: #2563eb; /* Bootstrap blue or use #1D4ED8 for deeper blue */
300
+ border-color: #2563eb;
301
+ }
302
+
303
+ .custom-switch .custom-control-label::before {
304
+ transition: all 0.3s ease-in-out;
305
+ }
306
+
307
+ .custom-switch .custom-control-input:focus ~ .custom-control-label::before {
308
+ box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.25);
309
+ }
310
+ </style>
92
311
 
93
312
  <!-- Main Content -->
94
313
  <div class="main-content" id="mainContent">
95
314
  <div class="container-fluid p-4">
96
- <!-- Content Header -->
97
- <div class="row align-items-center mb-3">
315
+
316
+
317
+ <div class="row">
318
+ <div class="col-lg-7 col-xl-5">
319
+ <!-- Content Header -->
320
+ <div class="row align-items-center">
98
321
  <div class="col-auto">
99
322
  <div class="content-header-icon">💡</div>
100
323
  </div>
101
- <div class="col">
324
+
102
325
  <h1 class="content-title">{{pageData.h1}}</h1>
103
- </div>
326
+
104
327
  </div>
105
-
106
- <div class="row">
107
- <div class="col-lg-8 col-xl-6">
108
328
  <p class="content-description">{{pageData.h2}}</p>
109
329
 
110
330
  <!-- FORM START -->
111
331
  <form id="contentToolForm">
112
332
  <!-- Standard Inputs -->
113
- {% for input in pageData.inputs %}
114
- <div class="mb-3">
115
- <label class="form-label">{{ input.label }}</label>
116
-
117
- {% if input.type == "text" %}
118
- <input type="text" name="{{ input.name }}" placeholder="{{ input.placeholder }}" class="form-control" />
119
-
120
- {% elsif input.type == "select" %}
121
- <select class="form-control" name="{{ input.name }}">
122
- {% for option in input.options %}
123
- <option value="{{ option }}">{{ option }}</option>
124
- {% endfor %}
125
- </select>
126
-
127
- {% elsif input.type == "textarea" %}
128
- <textarea name="{{ input.name }}" placeholder="{{ input.placeholder }}" rows="3"
129
- class="form-control"></textarea>
130
-
131
- {% endif %}
132
- </div>
133
- {% endfor %}
134
-
333
+ {% for input in pageData.inputs %}
334
+ <div class="mb-3">
335
+ {% if input.type == "text" %}
336
+ <label class="form-label">{{ input.label }}</label>
337
+ <input
338
+ type="text"
339
+ name="{{ input.name }}"
340
+ placeholder="{{ input.placeholder }}"
341
+ class="form-control"
342
+ />
343
+
344
+ {% elsif input.type == "select" %}
345
+ <label class="form-label">{{ input.label }}</label>
346
+ <select class="form-control" name="{{ input.name }}">
347
+ {% for option in input.options %}
348
+ <option value="{{ option }}">{{ option }}</option>
349
+ {% endfor %}
350
+ </select>
351
+
352
+ {% elsif input.type == "textarea" %}
353
+ <label class="form-label">{{ input.label }}</label>
354
+ <textarea
355
+ name="{{ input.name }}"
356
+ placeholder="{{ input.placeholder }}"
357
+ rows="3"
358
+ class="form-control"
359
+ ></textarea>
360
+
361
+ {% elsif input.type == "checkbox" %}
362
+ <div class="custom-control custom-switch">
363
+ <input
364
+ type="checkbox"
365
+ class="custom-control-input"
366
+ id="{{ input.name }}"
367
+ name="{{ input.name }}"
368
+ />
369
+ <label class="custom-control-label" for="{{ input.name }}">
370
+ {{ input.label }}
371
+ </label>
372
+ </div>
373
+ {% endif %}
374
+ </div>
375
+ {% endfor %}
135
376
 
136
377
  <div class="advanced-options mb-3" data-toggle="collapse" data-target="#advancedOptions">
137
378
  <div class="d-flex justify-content-between align-items-center">
@@ -162,29 +403,48 @@ assign boxColor = site.data[page.folderName][page.lang][page.fileName].color -%}
162
403
  <!-- Submit -->
163
404
  <div class="mt-4">
164
405
  <button type="submit" class="w-100 btn-generate">
165
- Generate Content
406
+ ⁺₊✧ Generate content
166
407
  </button>
167
408
  </div>
409
+ <div>
410
+ <button type="button" id="sample-data" class="sample-data">Fill With Sample Data</button>
411
+ </div>
168
412
  </form>
169
413
  <!-- FORM END -->
170
414
  </div>
171
-
172
- <!-- Quill Editor -->
173
- <div class="col-lg-4 col-xl-6">
174
- <div id="editor" style="height: 300px; background: #fff"></div>
415
+
416
+ <!-- Quill Editor Column -->
417
+ <div class="col-lg-5 col-xl-7">
418
+ <div id="editor" style="height: 100%; background: #fff"></div>
175
419
  </div>
420
+
176
421
  </div>
177
422
 
178
423
  <!-- Quill.js CDN -->
179
424
  <link href="https://cdn.quilljs.com/1.3.6/quill.snow.css" rel="stylesheet" />
180
425
  <script src="https://cdn.quilljs.com/1.3.6/quill.min.js"></script>
181
426
 
182
- <!-- Init Quill -->
427
+ <!-- Initialize Quill Editor (Simple Version) -->
183
428
  <script>
429
+ // Initialize Quill with basic toolbar (NO custom copy button here)
184
430
  var quill = new Quill("#editor", {
185
431
  theme: "snow",
186
432
  placeholder: "Your generated content will appear here...",
433
+ modules: {
434
+ toolbar: [
435
+ [{ 'header': [1, 2, 3, false] }],
436
+ ['bold', 'italic', 'underline', 'strike'],
437
+ [{ 'list': 'ordered'}, { 'list': 'bullet' }],
438
+ [{ 'color': [] }, { 'background': [] }],
439
+ [{ 'align': [] }],
440
+ ['link'],
441
+ ['clean']
442
+ ]
443
+ }
187
444
  });
445
+
446
+ // Make quill globally available
447
+ window.quill = quill;
188
448
  </script>
189
449
  </div>
190
450
  </div>
@@ -192,7 +452,7 @@ assign boxColor = site.data[page.folderName][page.lang][page.fileName].color -%}
192
452
  <!-- Bootstrap 4.6 JS Bundle -->
193
453
  <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
194
454
  <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/4.6.2/js/bootstrap.bundle.min.js"></script>
195
-
455
+
196
456
  <script>
197
457
  function toggleSidebar() {
198
458
  const sidebar = document.getElementById("sidebar");
@@ -298,6 +558,7 @@ assign boxColor = site.data[page.folderName][page.lang][page.fileName].color -%}
298
558
  $('[data-toggle="tooltip"]').tooltip();
299
559
  });
300
560
  </script>
561
+
301
562
  {%- if site.customCode -%} {%- include customCode.html -%} {%- endif -%} {%-
302
563
  include appscms/scripts/script.html -%}
303
564
  </body>
data/assets/.DS_Store CHANGED
Binary file