serveredit.vue 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <template>
  2. <form action="/api/servers/add" method="post">
  3. <div class="row editor form-group">
  4. <div class="col-4">
  5. <input class="form-control" placeholder="Name" name="name">
  6. </input>
  7. </div>
  8. <div class="col-3">
  9. <select class="form-control" name="type">
  10. <option value="">Server type</option>
  11. <option v-for="(option, key) in $root.types" :value="option">
  12. {{key}}
  13. </option>
  14. </select>
  15. </div>
  16. <div class="col-3">
  17. <input class="form-control" placeholder="Address" name="address">
  18. </input>
  19. </div>
  20. <div class="col-2">
  21. <button type="submit" class="btn btn-primary">{{buttonText}}</button>
  22. </div>
  23. </div>
  24. </form>
  25. </template>
  26. <script>
  27. import swal from "sweetalert2";
  28. import $ from "jquery";
  29. export default {
  30. mounted: function () {
  31. this.request();
  32. },
  33. props: {
  34. server: {
  35. type: Object,
  36. default:function () {
  37. return {
  38. id:0,
  39. name: "Name",
  40. address: "Address",
  41. players: 0,
  42. maxPlayers: 0,
  43. isPassword: false
  44. };
  45. }
  46. },
  47. update: {
  48. type: Function
  49. },
  50. onSubmit: {
  51. type: Function,
  52. default: function () {
  53. }
  54. },
  55. buttonText: {
  56. type: String,
  57. default: function () {
  58. return "Add";
  59. }
  60. }
  61. },
  62. data: function () {
  63. return {};
  64. },
  65. methods: {
  66. request: function () {
  67. var self = this;
  68. var form = $(this.$el);
  69. form.submit(function(e){
  70. e.preventDefault();
  71. // Validation
  72. var ar = form.serializeArray();
  73. var flags = {
  74. name: 0,
  75. type: 0,
  76. address: 0
  77. }
  78. ar.forEach(function (obj) {
  79. if(!obj.value){
  80. flags[obj.name] = 1;
  81. }
  82. });
  83. var wrong = false;
  84. for (var name in flags) {
  85. var el = $('[name="'+name+'"]')
  86. if (!flags.hasOwnProperty(name)) {
  87. continue;
  88. }
  89. if(flags[name]){
  90. wrong = true;
  91. el.addClass("form-control-danger");
  92. el.parent().addClass("has-danger");
  93. }else{
  94. el.removeClass("form-control-danger");
  95. el.parent().removeClass("has-danger")
  96. }
  97. }
  98. if(wrong){
  99. swal({
  100. titleText: "Wrong input",
  101. text:"Provide all data about server",
  102. type:"error"
  103. });
  104. return;
  105. }
  106. // Request
  107. var req_add = new XMLHttpRequest();
  108. req_add.open('POST', '/api/servers/add');
  109. req_add.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
  110. req_add.onreadystatechange = function () {
  111. if (req_add.readyState == XMLHttpRequest.DONE &&
  112. req_add.status === 200) {
  113. self.$router.push("/");
  114. form.find("input, select").val("");
  115. self.onSubmit();
  116. }
  117. };
  118. req_add.send(form.serialize());
  119. });
  120. }
  121. }
  122. }
  123. </script>