You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

254 lines
9.0 KiB

  1. <div class="narrow">
  2. <?= partial('partials/header') ?>
  3. <div style="clear: both;">
  4. <div class="alert alert-success hidden" id="post_success"><strong>Success! Your post should be on your website now!</strong><br><a href="" id="post_href">View your post</a></div>
  5. <div class="alert alert-danger hidden" id="post_error"><strong>There was a problem saving your post. Your endpoint did not return a Location header.</strong><br>See <a href="/creating-a-micropub-endpoint">Creating a Micropub Endpoint</a> for more information.</div>
  6. </div>
  7. <form role="form" style="margin-top: 20px;" id="note_form">
  8. <h2>Item</h2>
  9. <div class="row">
  10. <div class="col-xs-6">
  11. <div class="form-group">
  12. <label>Name</label>
  13. <input type="text" class="form-control" id="item_name" placeholder="" value="">
  14. </div>
  15. </div>
  16. <div class="col-xs-6">
  17. <div class="form-group">
  18. <label>URL</label>
  19. <input type="url" class="form-control" id="item_url" placeholder="" value="">
  20. </div>
  21. </div>
  22. </div>
  23. <h2>Review</h2>
  24. <div class="rating-stars">
  25. <a href="" data-rating="1"></a><a href="" data-rating="2"></a><a href="" data-rating="3"></a><a href="" data-rating="4"></a><a href="" data-rating="5"></a>
  26. <span class="description">It's okay</span>
  27. </div>
  28. <div class="row review-content hidden">
  29. <div class="col-xs-12">
  30. <div class="form-group">
  31. <textarea id="review_content" value="" class="form-control" style="height: 4em;" placeholder="Write your review here"></textarea>
  32. <div id="review-html-note">
  33. <input type="checkbox" id="review_is_html" value="1"> Post as HTML
  34. </div>
  35. </div>
  36. </div>
  37. </div>
  38. <div class="row review-summary hidden">
  39. <div class="col-xs-12">
  40. <div class="form-group">
  41. <input id="review_summary" value="" class="form-control" placeholder="Review summary">
  42. </div>
  43. </div>
  44. </div>
  45. <div class="row review-save hidden">
  46. <div class="col-xs-12">
  47. <div style="float: right; margin-top: 6px;">
  48. <button class="btn btn-success" id="btn_post">Post Review</button>
  49. </div>
  50. </div>
  51. </div>
  52. </form>
  53. </div>
  54. <style type="text/css">
  55. .rating-stars {
  56. display: flex;
  57. flex-direction: row;
  58. align-items: center;
  59. }
  60. .rating-stars .description {
  61. display: none;
  62. font-weight: bold;
  63. margin-left: 20px;
  64. }
  65. .rating-stars .description.visible {
  66. display: inline-block;
  67. }
  68. .rating-stars a {
  69. display: inline-block;
  70. width: 64px;
  71. height: 64px;
  72. background-repeat: no-repeat;
  73. background-image: url("data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHg9IjBweCIgeT0iMHB4IgogICB3aWR0aD0iNjRweCIgaGVpZ2h0PSI2NHB4IiB2aWV3Qm94PSIwIDAgNjQgNjQiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDY0IDY0IiB4bWw6c3BhY2U9InByZXNlcnZlIj48cG9seWdvbiBmaWxsPSJub25lIiBzdHJva2U9IiNBN0E5QUMiIHN0cm9rZS13aWR0aD0iNCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBwb2ludHM9IjMxLjg2Niw2LjYxOCA0MC4wOSwyMy4yODEgNTguNDc5LDI1Ljk1MyA0NS4xNzIsMzguOTIzIDQ4LjMxMyw1Ny4yMzkgMzEuODY2LDQ4LjU5MiAxNS40MTgsNTcuMjM5IDE4LjU2LDM4LjkyMyA1LjI1MywyNS45NTMgMjMuNjQyLDIzLjI4MSAiLz48L3N2Zz4=");
  74. }
  75. .rating-stars a.hover {
  76. background-image: url("data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeD0iMHB4IiB5PSIwcHgiCiAgIHdpZHRoPSI2NHB4IiBoZWlnaHQ9IjY0cHgiIHZpZXdCb3g9IjAgMCA2NCA2NCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNjQgNjQiIHhtbDpzcGFjZT0icHJlc2VydmUiPjxwb2x5Z29uIGZpbGw9IiM1MUFFQ0QiIHN0cm9rZT0iIzUxQUVDRCIgc3Ryb2tlLXdpZHRoPSI0IiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIHBvaW50cz0iMzEuODY2LDYuNjE4IDQwLjA5LDIzLjI4MSA1OC40NzksMjUuOTUzIDQ1LjE3MiwzOC45MjMgNDguMzEzLDU3LjIzOSAzMS44NjYsNDguNTkyIDE1LjQxOCw1Ny4yMzkgMTguNTYsMzguOTIzIDUuMjUzLDI1Ljk1MyAyMy42NDIsMjMuMjgxICIvPjwvc3ZnPgo=");
  77. }
  78. .rating-stars a.selected {
  79. background-image: url("data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHg9IjBweCIgeT0iMHB4IgogICB3aWR0aD0iNjRweCIgaGVpZ2h0PSI2NHB4IiB2aWV3Qm94PSIwIDAgNjQgNjQiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDY0IDY0IiB4bWw6c3BhY2U9InByZXNlcnZlIj48cG9seWdvbiBmaWxsPSIjRkVDMjBGIiBzdHJva2U9IiNGRUMyMEYiIHN0cm9rZS13aWR0aD0iNCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBwb2ludHM9IjMxLjg2Niw2LjYxOCA0MC4wOSwyMy4yODEgNTguNDc5LDI1Ljk1MyA0NS4xNzIsMzguOTIzIDQ4LjMxMyw1Ny4yMzkgMzEuODY2LDQ4LjU5MiAxNS40MTgsNTcuMjM5IDE4LjU2LDM4LjkyMyA1LjI1MywyNS45NTMgMjMuNjQyLDIzLjI4MSAiLz48L3N2Zz4=");
  80. }
  81. .review-content {
  82. margin-top: 1em;
  83. }
  84. #review-html-note {
  85. font-size: 12px;
  86. text-align: right;
  87. }
  88. </style>
  89. <script>
  90. var selectedRating = 0;
  91. var userSelectedHTML = null;
  92. function isHTML(str) {
  93. var doc = new DOMParser().parseFromString(str, "text/html");
  94. return Array.from(doc.body.childNodes).some(node => node.nodeType === 1);
  95. }
  96. function isTouchDevice() {
  97. return 'ontouchstart' in document.documentElement;
  98. }
  99. function setSaveButtonState() {
  100. if(selectedRating > 0 && $("#item_name").val() != "" && $("#item_url").val() != "") {
  101. $(".review-save").removeClass("hidden");
  102. } else {
  103. $(".review-save").addClass("hidden");
  104. }
  105. }
  106. $(function(){
  107. $(".rating-stars a").on("mouseover",function(){
  108. // Disable hover effects on touch devices
  109. if(isTouchDevice()) { return; }
  110. $(this).addClass("hover");
  111. var to = intval($(this).data("rating"));
  112. $(".rating-stars a").removeClass("selected");
  113. for(var i=1; i<=to; i++) {
  114. $(".rating-stars a[data-rating="+i+"]").addClass("hover").removeClass("selected");
  115. }
  116. var description;
  117. switch(to) {
  118. case 1:
  119. description = "I hate it"; break;
  120. case 2:
  121. description = "I don't like it"; break;
  122. case 3:
  123. description = "It's okay"; break;
  124. case 4:
  125. description = "I like it"; break;
  126. case 5:
  127. description = "I love it!"; break;
  128. }
  129. $(".rating-stars .description").text(description);
  130. $(".rating-stars span").addClass("visible");
  131. });
  132. $(".rating-stars a").on("mouseout",function(){
  133. $(this).removeClass("hover");
  134. });
  135. $(".rating-stars").on("mouseout",function(){
  136. $(".rating-stars span").removeClass("visible");
  137. $(".rating-stars a").removeClass("hover");
  138. if(selectedRating) {
  139. for(var i=1; i<=selectedRating; i++) {
  140. $(".rating-stars a[data-rating="+i+"]").addClass("selected")
  141. }
  142. }
  143. });
  144. $(".rating-stars a").on("click",function(){
  145. selectedRating = intval($(this).data("rating"));
  146. $(".rating-stars a").removeClass("hover").removeClass("selected");
  147. for(var i=1; i<=selectedRating; i++) {
  148. $(".rating-stars a[data-rating="+i+"]").addClass("selected")
  149. }
  150. $(".review-content").removeClass("hidden");
  151. setSaveButtonState();
  152. return false;
  153. });
  154. $("#review_is_html").on("click", function(){
  155. if($(this).attr("checked") == "checked") {
  156. userSelectedHTML = 1;
  157. } else {
  158. userSelectedHTML = -1;
  159. }
  160. });
  161. $("#review_content").on("keyup", function(){
  162. if(userSelectedHTML == null) {
  163. if(isHTML($(this).val())) {
  164. $("#review_is_html").attr("checked", "checked");
  165. } else {
  166. $("#review_is_html").removeAttr("checked");
  167. }
  168. }
  169. if($(this).val() != "") {
  170. $(".review-summary").removeClass("hidden");
  171. } else {
  172. $(".review-summary").addClass("hidden");
  173. }
  174. var scrollHeight = document.getElementById("review_content").scrollHeight;
  175. var currentHeight = parseInt($("#review_content").css("height"));
  176. if(Math.abs(scrollHeight - currentHeight) > 20) {
  177. $("#review_content").css("height", (scrollHeight+30)+"px");
  178. }
  179. });
  180. $("#item_name").on("keyup", setSaveButtonState);
  181. $("#item_url").on("keyup", setSaveButtonState);
  182. $("#btn_post").click(function(){
  183. $("#btn_post").addClass("loading disabled").text("Working...");
  184. var review = {
  185. item: [{
  186. type: "h-item",
  187. properties: {
  188. name: [$("#item_name").val()],
  189. url: [$("#item_url").val()]
  190. }
  191. }],
  192. rating: [selectedRating],
  193. };
  194. if($("#review_content").val() != "") {
  195. if($("#review_is_html").attr("checked") == "checked") {
  196. review["content"] = [{html: $("#review_content").val()}];
  197. } else {
  198. review["content"] = [$("#review_content").val()];
  199. }
  200. }
  201. if($("#review_summary").val() != "") {
  202. review["summary"] = [$("#review_summary").val()];
  203. }
  204. $.post("/micropub/postjson", {
  205. data: JSON.stringify({
  206. "type": "h-review",
  207. "properties": review
  208. })
  209. }, function(response){
  210. $("#btn_post").removeClass("loading disabled").text("Post Review");
  211. if(response.location != false) {
  212. $("#post_success").removeClass('hidden');
  213. $("#post_error").addClass('hidden');
  214. $("#post_href").attr("href", response.location);
  215. $("#note_form").addClass("hidden");
  216. } else {
  217. $("#post_success").addClass('hidden');
  218. $("#post_error").removeClass('hidden');
  219. }
  220. });
  221. return false;
  222. });
  223. });
  224. </script>