body {
    font-family: spartan;
    color: #444;
}

.jumbotron-img {
    background: rgb(237,116,88);
    background: linear-gradient(302deg, rgba(237,116,88,1) 16%, rgba(51,61,81,1) 97%);
    color: #fff;
}

.q-container {
    border-top-right-radius: .25rem;
    border-top-left-radius: .25rem;
    background-color: #efefee;
}

.q-container-show {
    border-top-right-radius: .25rem;
    border-top-left-radius: .25rem;
    background-color: #ED7458 ;
}

.q-container img, .q-container-show img {
    border: 2px solid #fff;
    border-radius: 50%;
}

.q-display {
    background: #fff;
    border-radius: .25rem;
}
.q-title-show {
    text-transform: uppercase;
    font-size: 1.3rem;
    color: #fff;
}
.q-title {
    text-transform: uppercase;
    color: #444;
}

.q-title:hover {
    color: #2B2B2B;
}

.q-title h2 {
    font-size: 1.3rem;
}

.q-display-response {
    background: #333D51;
    color: #fff;
}

.answer-link:hover .magic-wand {
    transform: rotate(20deg);
}

.vote-arrows, .vote-arrows .btn {
    font-size: 1.5rem;
}

.vote-arrows .btn {
    color: #444;
    padding: 0;
}

.vote-arrows span {
    font-size: 1rem;
}

.vote-up:hover {
    color: #3D9970;
}
.vote-down:hover {
    color: #FF4136;
}

.vote-arrows-alt .vote-up:hover {
    color: #3D9970;
}
.vote-arrows-alt .vote-down:hover {
    color: rgba(179, 20, 12, 0.63);
}

.btn-question {
    color: #FFFFFF;
    background-color: #ED7458;
    border-color: #D45B3F;
}

.btn-question:hover,
.btn-question:focus,
.btn-question:active,
.btn-question.active,
.open .dropdown-toggle.btn-question {
    color: #FFFFFF;
    background-color: #D45B3F;
    border-color: #D45B3F;
}

.btn-question:active,
.btn-question.active,
.open .dropdown-toggle.btn-question {
    background-image: none;
}

.btn-question.disabled,
.btn-question[disabled],
fieldset[disabled] .btn-question,
.btn-question.disabled:hover,
.btn-question[disabled]:hover,
fieldset[disabled] .btn-question:hover,
.btn-question.disabled:focus,
.btn-question[disabled]:focus,
fieldset[disabled] .btn-question:focus,
.btn-question.disabled:active,
.btn-question[disabled]:active,
fieldset[disabled] .btn-question:active,
.btn-question.disabled.active,
.btn-question[disabled].active,
fieldset[disabled] .btn-question.active {
    background-color: #ED7458;
    border-color: #D45B3F;
}

.btn-question .badge {
    color: #ED7458;
    background-color: #FFFFFF;
}

footer {
    background-color: #efefee;
}


.process-step .btn:focus{outline:none}
.process{display:table;width:100%;position:relative}
.process-row{display:table-row}
.process-step button[disabled]{opacity:1 !important;filter: alpha(opacity=100) !important}
.process-row:before{top:40px;bottom:0;position:absolute;content:" ";width:100%;height:1px;background-color:#ccc;z-order:0}
.process-step{display:table-cell;text-align:center;position:relative}
.process-step p{margin-top:4px}
.btn-circle{width:80px;height:80px;text-align:center;font-size:12px;border-radius:50%}

.tab-loading-overlay[data-v-9362ef2c] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  min-height: 200px;
}


.subcpmk-copy-row {
  background-color: rgba(13, 202, 240, 0.15) !important;
  border-left: 3px solid #0dcaf0 !important;
}
@media (prefers-color-scheme: dark) {
.subcpmk-copy-row {
    background-color: rgba(13, 202, 240, 0.2) !important;
    color: inherit !important;
}
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"app.css","mappings":"AAEA;IACI,oBAAoB;IACpB,WAAW;AACf;;AAEA;IACI,2BAA2B;IAC3B,iFAAiF;IACjF,WAAW;AACf;;AAEA;IACI,+BAA+B;IAC/B,8BAA8B;IAC9B,yBAAyB;AAC7B;;AAEA;IACI,+BAA+B;IAC/B,8BAA8B;IAC9B,0BAA0B;AAC9B;;AAEA;IACI,sBAAsB;IACtB,kBAAkB;AACtB;;AAEA;IACI,gBAAgB;IAChB,qBAAqB;AACzB;AACA;IACI,yBAAyB;IACzB,iBAAiB;IACjB,WAAW;AACf;AACA;IACI,yBAAyB;IACzB,WAAW;AACf;;AAEA;IACI,cAAc;AAClB;;AAEA;IACI,iBAAiB;AACrB;;AAEA;IACI,mBAAmB;IACnB,WAAW;AACf;;AAEA;IACI,wBAAwB;AAC5B;;AAEA;IACI,iBAAiB;AACrB;;AAEA;IACI,WAAW;IACX,UAAU;AACd;;AAEA;IACI,eAAe;AACnB;;AAEA;IACI,cAAc;AAClB;AACA;IACI,cAAc;AAClB;;AAEA;IACI,cAAc;AAClB;AACA;IACI,8BAA8B;AAClC;;AAEA;IACI,cAAc;IACd,yBAAyB;IACzB,qBAAqB;AACzB;;AAEA;;;;;IAKI,cAAc;IACd,yBAAyB;IACzB,qBAAqB;AACzB;;AAEA;;;IAGI,sBAAsB;AAC1B;;AAEA;;;;;;;;;;;;;;;IAeI,yBAAyB;IACzB,qBAAqB;AACzB;;AAEA;IACI,cAAc;IACd,yBAAyB;AAC7B;;AAEA;IACI,yBAAyB;AAC7B;;;AAGA,yBAAyB,YAAY;AACrC,SAAS,aAAa,CAAC,UAAU,CAAC,iBAAiB;AACnD,aAAa,iBAAiB;AAC9B,+BAA+B,oBAAoB,CAAC,qCAAqC;AACzF,oBAAoB,QAAQ,CAAC,QAAQ,CAAC,iBAAiB,CAAC,WAAW,CAAC,UAAU,CAAC,UAAU,CAAC,qBAAqB,CAAC,SAAS;AACzH,cAAc,kBAAkB,CAAC,iBAAiB,CAAC,iBAAiB;AACpE,gBAAgB,cAAc;AAC9B,YAAY,UAAU,CAAC,WAAW,CAAC,iBAAiB,CAAC,cAAc,CAAC,iBAAiB,C;;AC0sCrF;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;;;AAGA;EACA;EACA;AACA;AACA;AACA;IACA;IACA;AACA;AACA","sources":["webpack:///./assets/styles/app.css","webpack:///./assets/components/Tab.vue"],"sourcesContent":["@import \"~bootstrap\";\n\nbody {\n    font-family: spartan;\n    color: #444;\n}\n\n.jumbotron-img {\n    background: rgb(237,116,88);\n    background: linear-gradient(302deg, rgba(237,116,88,1) 16%, rgba(51,61,81,1) 97%);\n    color: #fff;\n}\n\n.q-container {\n    border-top-right-radius: .25rem;\n    border-top-left-radius: .25rem;\n    background-color: #efefee;\n}\n\n.q-container-show {\n    border-top-right-radius: .25rem;\n    border-top-left-radius: .25rem;\n    background-color: #ED7458 ;\n}\n\n.q-container img, .q-container-show img {\n    border: 2px solid #fff;\n    border-radius: 50%;\n}\n\n.q-display {\n    background: #fff;\n    border-radius: .25rem;\n}\n.q-title-show {\n    text-transform: uppercase;\n    font-size: 1.3rem;\n    color: #fff;\n}\n.q-title {\n    text-transform: uppercase;\n    color: #444;\n}\n\n.q-title:hover {\n    color: #2B2B2B;\n}\n\n.q-title h2 {\n    font-size: 1.3rem;\n}\n\n.q-display-response {\n    background: #333D51;\n    color: #fff;\n}\n\n.answer-link:hover .magic-wand {\n    transform: rotate(20deg);\n}\n\n.vote-arrows, .vote-arrows .btn {\n    font-size: 1.5rem;\n}\n\n.vote-arrows .btn {\n    color: #444;\n    padding: 0;\n}\n\n.vote-arrows span {\n    font-size: 1rem;\n}\n\n.vote-up:hover {\n    color: #3D9970;\n}\n.vote-down:hover {\n    color: #FF4136;\n}\n\n.vote-arrows-alt .vote-up:hover {\n    color: #3D9970;\n}\n.vote-arrows-alt .vote-down:hover {\n    color: rgba(179, 20, 12, 0.63);\n}\n\n.btn-question {\n    color: #FFFFFF;\n    background-color: #ED7458;\n    border-color: #D45B3F;\n}\n\n.btn-question:hover,\n.btn-question:focus,\n.btn-question:active,\n.btn-question.active,\n.open .dropdown-toggle.btn-question {\n    color: #FFFFFF;\n    background-color: #D45B3F;\n    border-color: #D45B3F;\n}\n\n.btn-question:active,\n.btn-question.active,\n.open .dropdown-toggle.btn-question {\n    background-image: none;\n}\n\n.btn-question.disabled,\n.btn-question[disabled],\nfieldset[disabled] .btn-question,\n.btn-question.disabled:hover,\n.btn-question[disabled]:hover,\nfieldset[disabled] .btn-question:hover,\n.btn-question.disabled:focus,\n.btn-question[disabled]:focus,\nfieldset[disabled] .btn-question:focus,\n.btn-question.disabled:active,\n.btn-question[disabled]:active,\nfieldset[disabled] .btn-question:active,\n.btn-question.disabled.active,\n.btn-question[disabled].active,\nfieldset[disabled] .btn-question.active {\n    background-color: #ED7458;\n    border-color: #D45B3F;\n}\n\n.btn-question .badge {\n    color: #ED7458;\n    background-color: #FFFFFF;\n}\n\nfooter {\n    background-color: #efefee;\n}\n\n\n.process-step .btn:focus{outline:none}\n.process{display:table;width:100%;position:relative}\n.process-row{display:table-row}\n.process-step button[disabled]{opacity:1 !important;filter: alpha(opacity=100) !important}\n.process-row:before{top:40px;bottom:0;position:absolute;content:\" \";width:100%;height:1px;background-color:#ccc;z-order:0}\n.process-step{display:table-cell;text-align:center;position:relative}\n.process-step p{margin-top:4px}\n.btn-circle{width:80px;height:80px;text-align:center;font-size:12px;border-radius:50%}","<!-- assets/js/components/Tabs.vue -->\n<template>\n  <div>\n    <div v-if=\"identitas.kode_mk\" class=\"alert alert-light border mb-3 py-2\">\n      <strong>{{ identitas.kode_mk }}</strong> — {{ identitas.mk }}\n    </div>\n    <ul class=\"nav nav-tabs\">\n      <li v-for=\"tab in tabs\" :key=\"tab.id\" class=\"nav-item\">\n        <a @click=\"loadTabContent(tab.id)\" :class=\"{ 'nav-link': true, active: activeTab === tab.id }\" href=\"#\">\n          {{ tab.label }}\n        </a>\n      </li>\n    </ul>\n\n    <div class=\"tab-content position-relative\">\n      <div v-if=\"loading\" class=\"tab-loading-overlay\">\n        <div class=\"spinner-border text-primary\" role=\"status\">\n          <span class=\"visually-hidden\">Loading...</span>\n        </div>\n      </div>\n      <div v-for=\"tab in tabs\" :key=\"tab.id\" class=\"tab-pane\" :class=\"{ active: activeTab === tab.id }\">\n        <div v-if=\"tab.id === 1\">\n          <table class=\"table table-hover w-50 mt-4\">\n            <tbody>\n              <tr>\n                <td>Nama Dosen</td>\n                <td>{{ identitas.dosen }}</td>\n              </tr>\n              <tr>\n                <td>Nama Mata Kuliah</td>\n                <td>{{ identitas.mk }}</td>\n              </tr>\n              <tr>\n                <td>Ambang Batas Kelulusan Mahasiswa</td>\n                <td>{{ identitas.ambang_mahasiswa }}</td>\n              </tr>\n              <tr>\n                <td>Ambang Batas Kelulusan Mata Kuliah </td>\n                <td>{{ identitas.ambang_mk }}</td>\n              </tr>\n            </tbody>\n          </table>\n          <b-button v-b-modal.modal-1>Edit Ambang Batas</b-button>\n          <b-modal id=\"modal-1\" title=\"Edit ambang batas\" @ok=\"handleEditAmbang()\" size=\"l\" no-close-on-backdrop no-close-on-esc>\n            <form>\n              <div class=\"form-group\">\n                <label for=\"exampleInputEmail1\">Ambang batas kelulusan mahasiswa</label>\n                <input type=\"number\" v-model=\"identitas.ambang_mahasiswa\" class=\"form-control\" id=\"ambang_mhs\" aria-describedby=\"ambang_mhsHelp\" placeholder=\"Masukkan nilai ambang batas kelulusan mahasiswa\">\n                <small id=\"ambang_mhsHelp\"   class=\"form-text text-muted\">Ambang kelulusan mahasiswa adalah nilai akhir mahasiswa yang di nyatakan lulus </small>\n              </div>\n              <div class=\"form-group\">\n                <input type=\"number\"  v-model=\"identitas.ambang_mk\" class=\"form-control\" id=\"ambang_mk\" aria-describedby=\"ambang_mkHelp\" placeholder=\"Masukkan nilai ambang batas kelulusan mk\">\n                <small id=\"ambang_mkHelp\" class=\"form-text text-muted\">Ambang kelulusan mata kuliah adalah nilai rata rata mhs yang menyatakan bawah kelas berhasil </small>\n              </div>\n            </form>\n          </b-modal>\n          <b-button v-b-modal.modal-copy variant=\"danger\">Copy/Import RPS dari RPS Mata Kuliah Lain</b-button>\n          <b-modal id=\"modal-copy\" title=\"Import RPS\" @ok=\"copyFrom()\" size=\"l\" no-close-on-backdrop no-close-on-esc>\n            <template>\n              <b-container fluid>\n                <!-- User Interface controls -->\n                <b-row>\n                  <b-col lg=\"12\" class=\"my-1\">\n                    <b-form-group\n                      label=\"Filter\"\n                      label-for=\"filter-input\"\n                      label-cols-sm=\"3\"\n                      label-align-sm=\"right\"\n                      label-size=\"sm\"\n                      class=\"mb-0\"\n                    >\n                      <b-input-group size=\"sm\">\n                        <b-form-input\n                          id=\"filter-input\"\n                          v-model=\"filter\"\n                          type=\"search\"\n                          placeholder=\"Type to Search\"\n                        ></b-form-input>\n\n                        <b-input-group-append>\n                          <b-button :disabled=\"!filter\" @click=\"filter = ''\">Clear</b-button>\n                        </b-input-group-append>\n                      </b-input-group>\n                    </b-form-group>\n                  </b-col>\n                  <b-table :items=\"listRps\" :fields=\"fields\" selectable :select-mode=\"'single'\" @row-selected=\"onRowSelectedRps\" ref=\"selectableTable\" :filter=\"filter\" @filtered=\"onFiltered\">\n                    <template #table-colgroup=\"scope\">\n                      <col\n                        v-for=\"field in scope.fields\"\n                        :key=\"field.key\"\n                      >\n                    </template>\n                  </b-table>\n                </b-row>\n              </b-container>\n            </template>\n          </b-modal>\n        </div>\n        <div v-if=\"tab.id === 2\">\n          <b-table striped hover :items=\"items\" :fields=\"fieldCpl\">\n            <template #table-colgroup=\"scope\">\n              <col\n                v-for=\"field in scope.fields\"\n                :key=\"field.key\"\n                :style=\"{ width: field.key === 'kodeCpl' ? '120px' : '' }\"\n              >\n            </template>\n            <template v-slot:cell(actions)=\"{ item }\">\n              <span><b-btn @click=\"hapusCpl(item)\">Hapus</b-btn></span>\n            </template>\n          </b-table>\n          <b-button v-b-modal.modal-2>Tambah CPL Prodi</b-button>\n          <b-modal id=\"modal-2\" title=\"Tambah CPL\" scrollable @ok=\"handlePilihCpl\" size=\"xl\" no-close-on-backdrop no-close-on-esc>\n            <template>\n              <b-container fluid>\n                <!-- User Interface controls -->\n                <b-row>\n                  <b-col lg=\"12\" class=\"my-1\">\n                  <b-form-group\n                    label=\"Filter\"\n                    label-for=\"filter-input\"\n                    label-cols-sm=\"3\"\n                    label-align-sm=\"right\"\n                    label-size=\"sm\"\n                    class=\"mb-0\"\n                  >\n                    <b-input-group size=\"sm\">\n                      <b-form-input\n                        id=\"filter-input\"\n                        v-model=\"filter\"\n                        type=\"search\"\n                        placeholder=\"Type to Search\"\n                      ></b-form-input>\n\n                      <b-input-group-append>\n                        <b-button :disabled=\"!filter\" @click=\"filter = ''\">Clear</b-button>\n                      </b-input-group-append>\n                    </b-input-group>\n                  </b-form-group>\n                </b-col>\n                     <b-table :items=\"pilihancpl\" :fields=\"fields\" selectable :select-mode=\"'multi'\" @row-selected=\"onRowSelected\" ref=\"selectableTable\" :filter=\"filter\" @filtered=\"onFiltered\">\n                      <template #table-colgroup=\"scope\">\n                        <col\n                          v-for=\"field in scope.fields\"\n                          :key=\"field.key\"\n                          :style=\"{ width: field.key === 'kodeCpl' ? '20%': '40%' }\"\n                        >\n                      </template>\n                    </b-table>\n                </b-row>\n              </b-container>\n            </template>\n          </b-modal>\n        </div>\n        <div v-if=\"tab.id === 3\">\n          <b-table striped hover :items=\"media\" :fields=\"fieldMedia\">\n            <template v-slot:cell(actions)=\"{ item }\">\n              <span>\n                <b-btn size=\"sm\" variant=\"primary\" @click=\"editMedia(item)\">Edit</b-btn>\n                <b-btn size=\"sm\" variant=\"danger\" @click=\"hapusMedia(item)\">Hapus</b-btn>\n              </span>\n            </template>\n          </b-table>\n          <b-button v-b-modal.modal-3>Tambah Media Pembelajaran</b-button>\n          <b-modal id=\"modal-3\" :title=\"fmedia.id ? 'Edit Media Pembelajaran' : 'Tambah Media Pembelajaran'\" @ok=\"handleMedia\" @hidden=\"resetMedia\" size=\"l\" no-close-on-backdrop no-close-on-esc>\n            <form>\n              Tanda * menandakan wajib di isi\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">* Nama media</label>\n                <input type=\"text\" v-model=\"fmedia.nama\" class=\"form-control\" id=\"nama_media\" aria-describedby=\"namamediahelp\" placeholder=\"Masukkan nama media\">\n                <small id=\"namamediahelp\"   class=\"form-text text-muted\">Media bantu pembelakaran contoh : power point, quizzez, papan tulis, komputer, proyektor </small>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">* Kategori</label>\n                <input type=\"text\"  v-model=\"fmedia.kategori\" class=\"form-control\" id=\"kategori\" aria-describedby=\"kategorihelp\" placeholder=\"Masukkan kategori\">\n                <small id=\"kategorihelp\" class=\"form-text text-muted\">Kategori media, contoh : software, hardware </small>\n              </div>\n            </form>\n          </b-modal>\n        </div>\n        <div v-if=\"tab.id === 4\">\n          <b-table striped hover :items=\"sumber\" :fields=\"fieldSumber\">\n            <template v-slot:cell(actions)=\"{ item }\">\n              <span>\n                <b-btn size=\"sm\" variant=\"primary\" @click=\"editSumber(item)\">Edit</b-btn>\n                <b-btn size=\"sm\" variant=\"danger\" @click=\"hapusSumber(item)\">Hapus</b-btn>\n              </span>\n            </template>\n          </b-table>\n          <b-button v-b-modal.modal-4>Tambah Sumber</b-button>\n          <b-modal id=\"modal-4\" :title=\"fsumber.id ? 'Edit Sumber' : 'Tambah Sumber'\" @ok=\"handlePustaka\" @hidden=\"resetSumber\" size=\"l\" no-close-on-backdrop no-close-on-esc>\n            <form>\n              Tanda * menandakan wajib di isi\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">*Nama sumber pustaka</label>\n                <input type=\"text\" v-model=\"fsumber.nama\" class=\"form-control\" id=\"nama_media\" aria-describedby=\"namamediahelp\" placeholder=\"Masukkan nama media\">\n                <small id=\"namamediahelp\"   class=\"form-text text-muted\">Sumber bahan ajar </small>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">* Kategori</label>\n                <input type=\"text\"  v-model=\"fsumber.kategori\" class=\"form-control\" id=\"kategori\" aria-describedby=\"kategorihelp\" placeholder=\"Masukkan kategori\">\n                <small id=\"kategorihelp\" class=\"form-text text-muted\">Kategori contoh buku, jurnal , dll </small>\n              </div>\n            </form>\n          </b-modal>\n        </div>\n        <div v-if=\"tab.id === 5\">\n          <b-table striped hover :items=\"cpmk\" :fields=\"fieldCpmk\">\n            <template v-slot:cell(namaCpmk)=\"{ item }\">\n              <div v-html=\"item.namaCpmk\"> </div>\n            </template>\n            <template v-slot:cell(actions)=\"{ item }\">\n              <span>\n                <b-btn size=\"sm\" variant=\"primary\" @click=\"editCpmk(item)\">Edit</b-btn>\n                <b-btn size=\"sm\" variant=\"danger\" @click=\"hapusCpmk(item)\">Hapus</b-btn>\n              </span>\n            </template>\n          </b-table>\n          <b-button v-b-modal.modal-5>Tambah CPMK</b-button>\n          <b-modal id=\"modal-5\" title=\"Tambah CPMK\" @ok=\"handleCpmk\" @hidden=\"resetCmpk\" size=\"xl\" no-close-on-backdrop no-close-on-esc>\n            <form>\n              <div class=\"row\">\n                <div class=\"col-6\">\n                  <div class=\"form-group\">\n                    <label for=\"cpl\">Capaian Profile Lulusan</label>\n                    <b-form-select v-model=\"fcpmk.kodeCpl\" :options=\"optionsCpl\" class=\"form-control\">\n                      <template #first>\n                        <b-form-select-option :value=\"null\" disabled>-- Silahkan pilih --</b-form-select-option>\n                      </template>\n                    </b-form-select>\n                    <small id=\"cpl\"   class=\"form-text text-muted\">Pilih capain profile lulusan yang dibebannkan pada mata kuliah ini </small>\n                  </div>\n                </div>\n                <div class=\"col-6\">\n                  <div class=\"form-group\">\n                        <label for=\"namaMedia\">Kode CPMK</label>\n                        <input type=\"text\" size=\"10\"  v-model=\"fcpmk.kodeCpmk\" class=\"form-control\" id=\"kategori\" aria-describedby=\"kategorihelp\" placeholder=\"Masukkan kode cpmk\">\n                        <small id=\"namamediahelp\"   class=\"form-text text-muted\">Kode CPMK biasanya berupa CPMK001, CPMK002 , dst nya .. </small>\n                  </div>\n                </div>\n              </div>\n              <div class=\"row\">\n                <div class=\"col-4\">\n                  <div class=\"form-group\">\n                    <div class=\"row\">\n                      <div class=\"col-12\">\n                        <label for=\"namaMedia\">Kode Bloom Cognitif</label>\n                        <b-form-select v-model=\"fcpmk.kodeBloomC\" :options=\"opsiBloomsC\" class=\"form-control\" v-on:change=\"getKataKerjaCcpmk()\">\n                          <template #first>\n                            <b-form-select-option :value=\"null\" disabled>-- Silahkan pilih --</b-form-select-option>\n                          </template>\n                        </b-form-select>\n                      </div>\n                      <div class=\"col-12 mt-2\">\n                        <div class=\"alert alert-info\" v-if=\"bloomCWordCpmk.length>0\" >\n                          <strong>Kata kerja yang dapat digunakan : </strong> <br />\n                          <span v-for=\"w in bloomCWordCpmk\">\n                            <b-badge variant=\"info\">{{ w }}</b-badge>\n                          </span>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n                <div class=\"col-4\">\n                  <div class=\"form-group\">\n                    <div class=\"row\">\n                      <div class=\"col-12\">\n                        <label for=\"namaMedia\">Kode Bloom Afektif</label>\n                        <b-form-select v-model=\"fcpmk.kodeBloomA\" :options=\"opsiBloomsA\" class=\"form-control\" v-on:change=\"getKataKerjaAcpmk()\">\n                          <template #first>\n                            <b-form-select-option :value=\"null\">-- Silahkan pilih --</b-form-select-option>\n                          </template>\n                        </b-form-select>\n                      </div>\n                      <div class=\"col-12 mt-2\">\n                        <div class=\"alert alert-info\" v-if=\"bloomAWordCpmk.length>0\" >\n                          <strong>Kata kerja yang dapat digunakan : </strong> <br />\n                          <span v-for=\"w in bloomAWordCpmk\">\n                            <b-badge variant=\"info\">{{ w }}</b-badge>\n                          </span>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n                <div class=\"col-4\">\n                  <div class=\"form-group\">\n                    <div class=\"row\">\n                      <div class=\"col-12\">\n                        <label for=\"namaMedia\">Kode Bloom Psikomotori</label>\n                        <b-form-select v-model=\"fcpmk.kodeBloomP\" :options=\"opsiBloomsP\" class=\"form-control\" v-on:change=\"getKataKerjaPcpmk()\">\n                          <template #first>\n                            <b-form-select-option :value=\"null\">-- Silahkan pilih --</b-form-select-option>\n                          </template>\n                        </b-form-select>\n                      </div>\n                      <div class=\"col-12 mt-2\">\n                        <div class=\"alert alert-info\" v-if=\"bloomPWordCpmk.length>0\" >\n                          <strong>Kata kerja yang dapat digunakan : </strong> <br />\n                          <span v-for=\"w in bloomPWordCpmk\">\n                            <b-badge variant=\"info\">{{ w }}</b-badge>\n                          </span>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Deskripsi CPMK</label>\n                <vue-editor\n                  v-model=\"fcpmk.namaCpmk\"\n                ></vue-editor>\n                <small id=\"namamediahelp\"   class=\"form-text text-muted\">Deskripsi capaian mata kuliah mengandung <strong> kata kerja </strong> sesuai dengan <strong> Taxonomy blooms </strong> yang di pilih, contoh : mahasiswa mampu <strong> merancang </strong> , <strong> menyebutkan </strong>, <strong> mebangun </strong></small>\n              </div>\n            </form>\n          </b-modal>\n        </div>\n        <div v-if=\"tab.id === 6\">\n          <div class=\"d-flex align-items-center justify-content-between mb-3 mt-3\">\n            <div>\n              <b-button v-b-modal.modal-6>Tambah Sub CPMK</b-button>\n              <b-button variant=\"success\" @click=\"syncToMoodle()\" :disabled=\"syncLoading\" class=\"ml-2\">\n                <span v-if=\"syncLoading\">\n                  <b-spinner small></b-spinner> Syncing...\n                </span>\n                <span v-else>Sync ke Moodle</span>\n              </b-button>\n            </div>\n            <b-badge :variant=\"totalProsentase === 100 ? 'success' : 'danger'\" class=\"px-3 py-2\" style=\"font-size: 0.95rem;\">\n              Total Prosentase: {{ totalProsentase }}%\n            </b-badge>\n          </div>\n          <b-alert v-if=\"syncResult\" :variant=\"syncResult.success ? 'success' : 'danger'\" show dismissible @dismissed=\"syncResult = null\" class=\"mb-3\">\n            <div v-if=\"syncResult.success\">\n              <strong>Sync berhasil!</strong> {{ syncResult.total_courses }} course ditemukan.\n              <div v-for=\"(r, idx) in syncResult.results\" :key=\"idx\" class=\"mt-1\">\n                <strong>{{ r.shortname }}</strong> ({{ r.idnumber }}):\n                <span v-if=\"r.status === 'synced'\">\n                  Topik: {{ r.updated }} updated, {{ r.inserted }} inserted |\n                  Kategori Nilai: {{ r.cpl_synced }} CPL, {{ r.cpmk_synced }} CPMK\n                  <span v-if=\"r.errors && r.errors.length > 0\" class=\"text-danger\"><br>Errors: {{ r.errors.join(', ') }}</span>\n                </span>\n                <span v-else class=\"text-warning\">{{ r.message }}</span>\n              </div>\n            </div>\n            <div v-else>\n              <strong>Gagal:</strong> {{ syncResult.error }}\n            </div>\n          </b-alert>\n          <b-input-group size=\"sm\" class=\"mb-3\" style=\"max-width: 400px;\">\n            <b-form-input v-model=\"subcpmkFilter\" type=\"search\" placeholder=\"Cari Sub CPMK...\"></b-form-input>\n            <b-input-group-append>\n              <b-button :disabled=\"!subcpmkFilter\" @click=\"subcpmkFilter = ''\">Clear</b-button>\n            </b-input-group-append>\n          </b-input-group>\n          <b-table striped hover :items=\"subcpmk\" :fields=\"fieldSubCpmk\" :filter=\"subcpmkFilter\" :tbody-tr-class=\"subcpmkRowClass\">\n            <template #cell(no)=\"item\">\n              {{ item.index + 1 }}\n            </template>\n            <template v-slot:cell(urutan)=\"{ item, index }\">\n              <b-btn size=\"sm\" variant=\"outline-secondary\" @click=\"moveSubCpmk(item, 'up')\" :disabled=\"index === 0\" class=\"px-1 py-0\">&#9650;</b-btn>\n              <b-btn size=\"sm\" variant=\"outline-secondary\" @click=\"moveSubCpmk(item, 'down')\" :disabled=\"index === subcpmk.length - 1\" class=\"px-1 py-0 ml-1\">&#9660;</b-btn>\n            </template>\n            <template v-slot:cell(actions)=\"{ item }\">\n              <b-btn size=\"sm\" variant=\"primary\" @click=\"editSubCpmk(item)\">Edit</b-btn>\n              <b-btn size=\"sm\" variant=\"info\" @click=\"copySubCpmk(item)\" class=\"ml-1\">Copy</b-btn>\n              <b-btn size=\"sm\" variant=\"danger\" @click=\"hapusSubCpmk(item)\" class=\"ml-1\">Hapus</b-btn>\n            </template>\n            <template v-slot:cell(deskripsi)=\"{ item }\">\n              <div v-if=\"item.deskripsi\"> <strong> Deskripsi : </strong> <span v-html=\"item.deskripsi\"> </span> </div>\n              <div v-if=\"item.materi\"> <strong> Materi : </strong> <span v-html=\"item.materi\"> </span></div>\n              <div v-if=\"item.indikator\"><strong> Indikator : </strong> <span v-html=\"item.indikator\"> </span></div>\n              <div v-if=\"item.metode\"><strong> Metode : </strong> <span v-html=\"item.metode\"> </span></div>\n              <div v-if=\"item.luring\"><strong> Luring : </strong> <span v-html=\"item.luring\"> </span></div>\n              <div v-if=\"item.daring\"><strong> Daring : </strong> <span v-html=\"item.daring\"> </span></div>\n              <div v-if=\"item.pustaka\"> <strong> Pustaka : </strong> <span v-html=\"item.pustaka\"> </span></div>\n            </template>\n            <template v-slot:cell(assesment)=\"{ item }\">\n              <strong> Bentuk Assesment : </strong> {{ item.bentukAssesment }} <br />\n              <strong> Nama Assesment : </strong> {{ item.namaAssesment }} <br />\n            </template>\n          </b-table>\n          <b-modal id=\"modal-6\" title=\"Tambah Sub CPMK\" scrollable @ok=\"handleSubCpmk\" size=\"xl\" @hidden=\"resetSubCmpk\" no-close-on-backdrop no-close-on-esc>\n            <form>\n              <div class=\"row\">\n                <div class=\"col-6\">\n                  <div class=\"form-group\">\n                    <label for=\"namaMedia\">Minggu ke</label>\n                    <input type=\"text\"  v-model=\"fscpmk.mingguke\" class=\"form-control\" id=\"kategori\" aria-describedby=\"kategorihelp\" placeholder=\"Minggu ke berapa\" />\n                  </div>\n                </div>\n                <div class=\"col-6\">\n                  <div class=\"form-group\">\n                    <label for=\"namaMedia\">Pilih CPMK</label>\n                    <b-form-select v-model=\"fscpmk.kodeCpmk\" :options=\"optionsCpmk\" class=\"form-control\">\n                      <template #first>\n                        <b-form-select-option :value=\"null\" disabled>-- Silahkan pilih --</b-form-select-option>\n                      </template>\n                    </b-form-select>\n                  </div>\n                </div>\n              </div>\n              <div class=\"row\">\n                <div class=\"col-4\">\n                  <div class=\"form-group\">\n                    <div class=\"row\">\n                      <div class=\"col-12\">\n                        <label for=\"namaMedia\">Kode Bloom Cognitif</label>\n                        <b-form-select v-model=\"fscpmk.kodeBloomC\" :options=\"opsiBloomsC\" class=\"form-control\" v-on:change=\"getKataKerjaC()\">\n                          <template #first>\n                            <b-form-select-option :value=\"null\" disabled>-- Silahkan pilih --</b-form-select-option>\n                          </template>\n                        </b-form-select>\n                      </div>\n                      <div class=\"col-12 mt-2\">\n                        <div class=\"alert alert-info\" v-if=\"bloomCWord.length>0\" >\n                          <strong>Kata kerja yang dapat digunakan : </strong> <br />\n                          <span v-for=\"w in bloomCWord\">\n                            <b-badge variant=\"info\">{{ w }}</b-badge>\n                          </span>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n                <div class=\"col-4\">\n                  <div class=\"form-group\">\n                    <div class=\"row\">\n                      <div class=\"col-12\">\n                        <label for=\"namaMedia\">Kode Bloom Afektif</label>\n                        <b-form-select v-model=\"fscpmk.kodeBloomA\" :options=\"opsiBloomsA\" class=\"form-control\" v-on:change=\"getKataKerjaA()\">\n                          <template #first>\n                            <b-form-select-option :value=\"null\">-- Silahkan pilih --</b-form-select-option>\n                          </template>\n                        </b-form-select>\n                      </div>\n                      <div class=\"col-12 mt-2\">\n                        <div class=\"alert alert-info\" v-if=\"bloomAWord.length>0\" >\n                          <strong>Kata kerja yang dapat digunakan : </strong> <br />\n                          <span v-for=\"w in bloomAWord\">\n                            <b-badge variant=\"info\">{{ w }}</b-badge>\n                          </span>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n                <div class=\"col-4\">\n                  <div class=\"form-group\">\n                    <div class=\"row\">\n                      <div class=\"col-12\">\n                        <label for=\"namaMedia\">Kode Bloom Psikomotori</label>\n                        <b-form-select v-model=\"fscpmk.kodeBloomP\" :options=\"opsiBloomsP\" class=\"form-control\" v-on:change=\"getKataKerjaP()\">\n                          <template #first>\n                            <b-form-select-option :value=\"null\">-- Silahkan pilih --</b-form-select-option>\n                          </template>\n                        </b-form-select>\n                      </div>\n                      <div class=\"col-12 mt-2\">\n                        <div class=\"alert alert-info\" v-if=\"bloomPWord.length>0\" >\n                          <strong>Kata kerja yang dapat digunakan : </strong> <br />\n                          <span v-for=\"w in bloomPWord\">\n                            <b-badge variant=\"info\">{{ w }}</b-badge>\n                          </span>\n                        </div>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Deskripsi Sub CPMK</label>\n                <vue-editor\n                  v-model=\"fscpmk.deskripsi\"\n                ></vue-editor>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Indikator</label>\n                <vue-editor\n                  v-model=\"fscpmk.indikator\"\n                ></vue-editor>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Materi</label>\n                <vue-editor\n                  v-model=\"fscpmk.materi\"\n                ></vue-editor>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Metode</label>\n                <vue-editor\n                  v-model=\"fscpmk.metode\"\n                ></vue-editor>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Luring</label>\n                <vue-editor\n                  v-model=\"fscpmk.luring\"\n                ></vue-editor>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Daring</label>\n                <vue-editor\n                  v-model=\"fscpmk.daring\"\n                ></vue-editor>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Bentuk Assesment</label>\n                <b-form-select v-model=\"fscpmk.bentukAssesment\" :options=\"opsiBentukAssesment\" class=\"form-control\">\n                  <template #first>\n                    <b-form-select-option :value=\"null\">-- Silahkan pilih bentuk assesment --</b-form-select-option>\n                  </template>\n                </b-form-select>\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Nama Assement</label>\n                <input type=\"text\"  v-model=\"fscpmk.namaAssesment\" class=\"form-control\" id=\"kategori\" aria-describedby=\"kategorihelp\" placeholder=\"Masukkan nama assesment\" />\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Prosentase</label>\n                <input type=\"number\"  v-model=\"fscpmk.prosentase\" class=\"form-control\" id=\"kategori\" aria-describedby=\"kategorihelp\" placeholder=\"Masukkan prosentase penilaian\" />\n              </div>\n              <div class=\"form-group\">\n                <label for=\"namaMedia\">Pilih pustaka yang digunakan</label>\n                <multiselect\n                  v-model=\"fscpmk.pustaka\"\n                  :multiple=\"true\"\n                  :close-on-select=\"false\"\n                  :clear-on-select=\"false\"\n                  :preserve-search=\"true\"\n                  placeholder=\"Pilih pustaka\"\n                  label=\"text\"\n                  track-by=\"text\"\n                  :options=\"opsiPustaka\">\n                </multiselect>\n              </div>\n\n            </form>\n          </b-modal>\n        </div>\n        <div v-if=\"tab.id === 7\">\n          <b-table striped hover :items=\"bk\" :fields=\"fieldBahanKajian\">\n            <template #table-colgroup=\"scope\">\n              <col\n                v-for=\"field in scope.fields\"\n                :key=\"field.key\"\n                :style=\"{ width: field.key === 'kodeBk' ? '120px' : '' }\"\n              >\n            </template>\n            <template v-slot:cell(actions)=\"{ item }\">\n              <span><b-btn @click=\"hapusBk(item)\">Hapus</b-btn></span>\n            </template>\n          </b-table>\n          <b-button v-b-modal.modal-7>Tambah Bahan Kajian</b-button>\n          <b-modal id=\"modal-7\" title=\"Tambah Bahan Kajian\" scrollable @ok=\"handlePilihBk\" size=\"xl\" no-close-on-backdrop no-close-on-esc>\n            <template>\n              <b-container fluid>\n                <!-- User Interface controls -->\n                <b-row>\n                  <b-col lg=\"12\" class=\"my-1\">\n                    <b-form-group\n                      label=\"Filter\"\n                      label-for=\"filter-input\"\n                      label-cols-sm=\"3\"\n                      label-align-sm=\"right\"\n                      label-size=\"sm\"\n                      class=\"mb-0\"\n                    >\n                      <b-input-group size=\"sm\">\n                        <b-form-input\n                          id=\"filter-input\"\n                          v-model=\"filter\"\n                          type=\"search\"\n                          placeholder=\"Type to Search\"\n                        ></b-form-input>\n\n                        <b-input-group-append>\n                          <b-button :disabled=\"!filter\" @click=\"filter = ''\">Clear</b-button>\n                        </b-input-group-append>\n                      </b-input-group>\n                    </b-form-group>\n                  </b-col>\n                  <b-table :items=\"pilihanbk\" :fields=\"['nama']\" selectable :select-mode=\"'multi'\" @row-selected=\"onRowSelectedBk\" ref=\"selectableTable\" :filter=\"filter\" @filtered=\"onFiltered\">\n                  </b-table>\n                </b-row>\n              </b-container>\n            </template>\n          </b-modal>\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n\n<script>\nimport axios from 'axios';\nimport Multiselect from 'vue-multiselect';\n\n\nconst formEditAmbang = {\n    'ambang_mk': null,\n    'ambang_mhs': null\n};\n\nexport default {\n  components: { Multiselect },\n  props: [\"rpsId\"],\n  data() {\n    return {\n      id: this.rpsId,\n      identitas: {\n        kode_mk: '',\n        mk : '',\n        dosen: '',\n        ambang_mahasiswa: 0,\n        ambang_mk: 0,\n        program_studi: null,\n      },\n      fmedia: {\n        id: null,\n        nama: '',\n        kategori: ''\n      },\n      fsumber: {\n        id: null,\n        nama: '',\n        kategori: ''\n      },\n      fcpmk: {\n        id: null,\n        kodeCpl: null,\n        kodeCpmk: '',\n        namaCpmk: '',\n        kodeBloomC: null,\n        kodeBloomA: null,\n        kodeBloomP: null\n      },\n      fscpmk: {\n        mingguke: null,\n        id: null,\n        kodeCpmk: null,\n        deskripsi: '',\n        indikator: '',\n        materi: '',\n        bentukAssesment: null,\n        namaAssesment: '',\n        metode: '',\n        luring: '',\n        daring: '',\n        prosentase: null,\n        kodeBloomC: null,\n        kodeBloomA: null,\n        kodeBloomP: null,\n        pustaka: [],\n      },\n      loading: false,\n      activeTab: 1,\n      tabs: [\n        { id: 1, label: 'Identitas dan Otorasi' },\n        { id: 2, label: 'CPL Prodi' },\n        { id: 3, label: 'Media Pembelajaran' },\n        { id: 4, label: 'Pustaka' },\n        { id: 5, label: 'CPMK' },\n        { id: 6, label: 'Sub CPMK' },\n        { id: 7, label: 'Bahan Kajian' }\n      ],\n      tabData: {},\n      listRps: [],\n      items: [],\n      pilihancpl: [],\n      bk: [],\n      pilihanbk: [],\n      media: [],\n      sumber: [],\n      cpmk: [],\n      subcpmk: [],\n      fields: [],\n      optionsCpl: [],\n      optionsCpmk: [],\n      opsiBloomsC: [],\n      opsiBloomsA: [],\n      opsiBloomsP: [],\n      opsiPustaka: [],\n      opsiBentukAssesment: [],\n      opsiBlooms: [],\n      selected: [],\n      selectedBk: [],\n      selectedRps: [],\n      fieldCpl: ['kodeCpl','cpl','aspek', 'actions'],\n      fieldBahanKajian: ['nama', 'actions'],\n      fieldMedia: ['nama','kategori', 'actions'],\n      fieldSumber: ['sumber','kategori', 'actions'],\n      fieldCpmk: ['kodeCPl', 'kodeCpmk','namaCpmk','bloom','actions'],\n      fieldSubCpmk: ['no','urutan','mingguke','kodeCpmk','deskripsi','assesment','prosentase','bloom','actions'],\n      syncLoading: false,\n      syncResult: null,\n      subcpmkFilter: null,\n      filter: null,\n      bloomCWord: \"\",\n      bloomAWord: \"\",\n      bloomPWord: \"\",\n      bloomCWordCpmk: \"\",\n      bloomAWordCpmk: \"\",\n      bloomPWordCpmk: \"\",\n      customToolbar: [\n        [\"bold\", \"italic\", \"underline\"],\n        [{ list: \"ordered\" }, { list: \"bullet\" }],\n      ],\n      optionsEditor: {\n        formats: [\n          'bold','underline','italic'\n        ],\n        modules: {\n          clipboard: {\n            matchVisual: false // https://quilljs.com/docs/modules/clipboard/#matchvisual\n          }\n        }\n      },\n    };\n  },\n  computed: {\n    totalProsentase() {\n      return this.subcpmk.reduce((sum, item) => sum + (parseInt(item.prosentase) || 0), 0);\n    }\n  },\n  methods: {\n    loadFirst(){\n      this.loading = true;\n      Promise.all([\n        axios.get(`/api/${this.rpsId}/identitas`).then(response => {\n          this.identitas.kode_mk = response.data.kode_mata_kuliah;\n          this.identitas.mk = response.data.nama_mata_kuliah;\n          this.identitas.dosen = response.data.dosen;\n          this.identitas.ambang_mahasiswa = response.data.ambang_batas_kelulusan_mahasiswa;\n          this.identitas.ambang_mk = response.data.ambang_batas_kelulusan_mata_kuliah;\n          this.identitas.program_studi = response.data.program_studi;\n        }),\n        axios.get(`/api/${this.rpsId}/list-rps`).then(response => {\n          this.listRps = response.data;\n        })\n      ]).catch(error => {\n        console.error('Error fetching identitas:', error);\n      }).finally(() => {\n        this.loading = false;\n      });\n    },\n    loadTabContent(tabId) {\n      this.loading = true;\n      this.activeTab = tabId;\n\n      var promises = [];\n\n      if (tabId === 1) {\n        promises = [\n          axios.get(`/api/${this.rpsId}/identitas`).then(response => {\n            this.identitas.mk = response.data.nama_mata_kuliah;\n            this.identitas.dosen = response.data.dosen;\n            this.identitas.ambang_mahasiswa = response.data.ambang_batas_kelulusan_mahasiswa;\n            this.identitas.ambang_mk = response.data.ambang_batas_kelulusan_mata_kuliah;\n            this.identitas.program_studi = response.data.program_studi;\n          }),\n          axios.get(`/api/${this.rpsId}/list-rps`).then(response => {\n            this.listRps = response.data;\n          })\n        ];\n      } else if (tabId === 2) {\n        promises = [\n          axios.get(`/api/${this.rpsId}/cpl`).then(response => {\n            this.items = response.data;\n          }),\n          axios.get(`/api/${this.rpsId}/pilihan-cpl/${this.identitas.program_studi}`).then(response => {\n            this.pilihancpl = response.data;\n          })\n        ];\n      } else if (tabId === 3) {\n        promises = [\n          axios.get(`/api/${this.rpsId}/media`).then(response => {\n            this.media = response.data;\n          })\n        ];\n      } else if (tabId === 4) {\n        promises = [\n          axios.get(`/api/${this.rpsId}/pustaka`).then(response => {\n            this.sumber = response.data;\n          })\n        ];\n      } else if (tabId === 5) {\n        promises = [\n          axios.get(`/api/${this.rpsId}/cpmk`).then(response => {\n            this.cpmk = response.data;\n          }),\n          axios.get(`/api/${this.rpsId}/opsicpl`).then(response => {\n            this.optionsCpl = response.data;\n          }),\n          axios.get(`/api/blooms-kognitif`).then(response => {\n            this.opsiBloomsC = response.data;\n          }),\n          axios.get(`/api/blooms-afektif`).then(response => {\n            this.opsiBloomsA = response.data;\n          }),\n          axios.get(`/api/blooms-psiko`).then(response => {\n            this.opsiBloomsP = response.data;\n          })\n        ];\n      } else if (tabId === 6) {\n        promises = [\n          axios.get(`/api/${this.rpsId}/subcpmk`).then(response => {\n            this.subcpmk = response.data;\n          }),\n          axios.get(`/api/${this.rpsId}/opsicpmk`).then(response => {\n            this.optionsCpmk = response.data;\n          }),\n          axios.get(`/api/opsibassesment`).then(response => {\n            this.opsiBentukAssesment = response.data;\n          }),\n          axios.get(`/api/blooms-kognitif`).then(response => {\n            this.opsiBloomsC = response.data;\n          }),\n          axios.get(`/api/blooms-afektif`).then(response => {\n            this.opsiBloomsA = response.data;\n          }),\n          axios.get(`/api/blooms-psiko`).then(response => {\n            this.opsiBloomsP = response.data;\n          }),\n          axios.get(`/api/${this.rpsId}/opsipustaka`).then(response => {\n            this.opsiPustaka = response.data;\n          })\n        ];\n      } else if (tabId === 7) {\n        promises = [\n          axios.get(`/api/${this.rpsId}/bk`).then(response => {\n            this.bk = response.data;\n          }),\n          axios.get(`/api/${this.rpsId}/pilihan-bk/${this.identitas.program_studi}`).then(response => {\n            this.pilihanbk = response.data;\n          })\n        ];\n      }\n\n      Promise.all(promises).catch(error => {\n        console.error(`Error fetching content for Tab ${tabId}:`, error);\n      }).finally(() => {\n        this.loading = false;\n      });\n    },\n    handleOk(bvModalEvent) {\n      this.$bvModal.hide('modal-prevent-closing')\n    },\n    handleEditAmbang(bvModalEvent) {\n\n      axios.post(`/api/${this.rpsId}/identitas`, {\n        ambang_mk: this.identitas.ambang_mk,\n        ambang_mhs: this.identitas.ambang_mahasiswa\n      })\n        .then(function (response) {\n          console.log(response);\n        })\n        .catch(function (error) {\n          console.log(error);\n        });\n\n      this.$bvModal.close('modal-prevent-closing')\n\n    },\n    handleMedia(bvModalEvent) {\n      var self = this;\n      if (!this.fmedia.nama || !this.fmedia.kategori || this.fmedia.nama === \"\" || this.fmedia.kategori === \"\") {\n          alert('nama dan kategori media pembelajaran harus di isi !');\n          bvModalEvent.preventDefault();\n      }else{\n        if (this.fmedia.id) {\n          axios.put(`/api/media/${this.fmedia.id}`, {\n            nama: this.fmedia.nama,\n            kategori: this.fmedia.kategori\n          })\n            .then(function (response) {\n              self.loadTabContent(3);\n            })\n            .catch(function (error) {\n              console.log(error);\n            });\n        } else {\n          axios.post(`/api/${this.rpsId}/media`, {\n            nama: this.fmedia.nama,\n            kategori: this.fmedia.kategori\n          })\n            .then(function (response) {\n              self.loadTabContent(3);\n            })\n            .catch(function (error) {\n              console.log(error);\n            });\n        }\n        this.$bvModal.hide('modal-prevent-closing');\n      }\n    },\n    editMedia(item) {\n      this.fmedia.id = item.id;\n      this.fmedia.nama = item.nama;\n      this.fmedia.kategori = item.kategori;\n      this.$bvModal.show('modal-3');\n    },\n    resetMedia() {\n      this.fmedia.id = null;\n      this.fmedia.nama = '';\n      this.fmedia.kategori = '';\n    },\n    handlePilihCpl(bvModalEvent) {\n      var self = this;\n      axios.post(`/api/${this.rpsId}/cpl`, this.selected)\n        .then(function (response) {\n          self.loadTabContent(2);\n        })\n        .catch(function (error) {\n          console.log(error);\n        });\n\n      this.$bvModal.hide('modal-prevent-closing');\n\n    },\n    copyFrom(bvModalEvent) {\n      var self = this;\n      axios.post(`/api/${this.rpsId}/copy-from`, this.selectedRps)\n        .then(function (response) {\n          self.loadTabContent(1);\n        })\n        .catch(function (error) {\n          console.log(error);\n        });\n      this.$bvModal.hide('modal-prevent-closing');\n\n    },\n    handlePilihBk(bvModalEvent) {\n      var self = this;\n      axios.post(`/api/${this.rpsId}/bk`, this.selectedBk)\n        .then(function (response) {\n          self.loadTabContent(7);\n        })\n        .catch(function (error) {\n          console.log(error);\n        });\n\n      this.$bvModal.hide('modal-prevent-closing');\n\n    },\n    handlePustaka(bvModalEvent) {\n      var self = this;\n      if (!this.fsumber.nama || !this.fsumber.kategori || this.fsumber.nama === \"\" || this.fsumber.kategori === \"\") {\n        alert('nama dan kategori media sumber pustaka harus di isi !');\n        bvModalEvent.preventDefault();\n      }else{\n        if (this.fsumber.id) {\n          axios.put(`/api/sumber/${this.fsumber.id}`, {\n            nama: this.fsumber.nama,\n            kategori: this.fsumber.kategori\n          })\n            .then(function (response) {\n              self.loadTabContent(4);\n            })\n            .catch(function (error) {\n              console.log(error);\n            });\n        } else {\n          axios.post(`/api/${this.rpsId}/pustaka`, {\n            nama: this.fsumber.nama,\n            kategori: this.fsumber.kategori\n          })\n            .then(function (response) {\n              self.loadTabContent(4);\n            })\n            .catch(function (error) {\n              console.log(error);\n            });\n        }\n        this.$bvModal.hide('modal-prevent-closing');\n      }\n    },\n    editSumber(item) {\n      this.fsumber.id = item.id;\n      this.fsumber.nama = item.sumber;\n      this.fsumber.kategori = item.kategori;\n      this.$bvModal.show('modal-4');\n    },\n    resetSumber() {\n      this.fsumber.id = null;\n      this.fsumber.nama = '';\n      this.fsumber.kategori = '';\n    },\n    handleCpmk(bvModalEvent) {\n      var self = this;\n      if (this.fcpmk.id) {\n        axios.put(`/api/cpmk/${this.fcpmk.id}`, {\n          kodeCpl: this.fcpmk.kodeCpl,\n          kodeCpmk: this.fcpmk.kodeCpmk,\n          namaCpmk: this.fcpmk.namaCpmk,\n          kodeBloomC: this.fcpmk.kodeBloomC,\n          kodeBloomA: this.fcpmk.kodeBloomA,\n          kodeBloomP: this.fcpmk.kodeBloomP\n        })\n          .then(function (response) {\n            self.loadTabContent(5);\n          })\n          .catch(function (error) {\n            console.log(error);\n          });\n      }else{\n        axios.post(`/api/${this.rpsId}/cpmk`, {\n          kodeCpl: this.fcpmk.kodeCpl,\n          kodeCpmk: this.fcpmk.kodeCpmk,\n          namaCpmk: this.fcpmk.namaCpmk,\n          kodeBloomC: this.fcpmk.kodeBloomC,\n          kodeBloomA: this.fcpmk.kodeBloomA,\n          kodeBloomP: this.fcpmk.kodeBloomP\n        })\n          .then(function (response) {\n            self.loadTabContent(5);\n          })\n          .catch(function (error) {\n            console.log(error);\n          });\n      }\n\n      this.fcpmk.id = null;\n      this.fcpmk.kodeCpl = null;\n      this.fcpmk.kodeCpmk= '';\n      this.fcpmk.namaCpmk= '';\n      this.fcpmk.kodeBloomC = null;\n      this.fcpmk.kodeBloomA = null;\n      this.fcpmk.kodeBloomA = null;\n      this.$bvModal.hide('modal-prevent-closing');\n\n    },\n    handleSubCpmk(bvModalEvent) {\n      var self = this;\n      if (this.fscpmk.id) {\n        axios.put(`/api/scpmk/${this.fscpmk.id}`, {\n          mingguke: this.fscpmk.mingguke,\n          kodeCpmk: this.fscpmk.kodeCpmk,\n          deskripsi: this.fscpmk.deskripsi,\n          indikator: this.fscpmk.indikator,\n          materi: this.fscpmk.materi,\n          bentukAssesment: this.fscpmk.bentukAssesment,\n          namaAssesment: this.fscpmk.namaAssesment,\n          metode: this.fscpmk.metode,\n          luring: this.fscpmk.luring,\n          daring: this.fscpmk.daring,\n          prosentase: this.fscpmk.prosentase,\n          kodeBloomC: this.fscpmk.kodeBloomC,\n          kodeBloomA: this.fscpmk.kodeBloomA,\n          kodeBloomP: this.fscpmk.kodeBloomP,\n          pustaka: this.fscpmk.pustaka\n        })\n          .then(function (response) {\n            self.loadTabContent(6);\n          })\n          .catch(function (error) {\n            console.error('Error update Sub CPMK:', error);\n            var msg = 'Gagal menyimpan Sub CPMK';\n            if (error.response && error.response.data && error.response.data.error) {\n              msg += ': ' + error.response.data.error;\n            }\n            alert(msg);\n          });\n      }else{\n        axios.post(`/api/${this.rpsId}/scpmk`, {\n          mingguke: this.fscpmk.mingguke,\n          kodeCpmk: this.fscpmk.kodeCpmk,\n          deskripsi: this.fscpmk.deskripsi,\n          indikator: this.fscpmk.indikator,\n          materi: this.fscpmk.materi,\n          bentukAssesment: this.fscpmk.bentukAssesment,\n          namaAssesment: this.fscpmk.namaAssesment,\n          metode: this.fscpmk.metode,\n          luring: this.fscpmk.luring,\n          daring: this.fscpmk.daring,\n          prosentase: this.fscpmk.prosentase,\n          kodeBloomC: this.fscpmk.kodeBloomC,\n          kodeBloomA: this.fscpmk.kodeBloomA,\n          kodeBloomP: this.fscpmk.kodeBloomP,\n          pustaka: this.fscpmk.pustaka\n        })\n          .then(function (response) {\n            self.loadTabContent(6);\n          })\n          .catch(function (error) {\n            console.log(error);\n          });\n      }\n      this.fscpmk.id = null;\n      this.fscpmk.kodeCpmk = null;\n      this.fscpmk.deskripsi = '';\n      this.fscpmk.indikator = '';\n      this.fscpmk.materi = '';\n      this.fscpmk.bentukAssesment = null;\n      this.fscpmk.namaAssesment = '';\n      this.fscpmk.metode = '';\n      this.fscpmk.luring = '';\n      this.fscpmk.daring = '';\n      this.fscpmk.prosentase = null;\n      this.fscpmk.kodeBloomC = null;\n      this.fscpmk.kodeBloomA = null;\n      this.fscpmk.kodeBloomP = null;\n\n      this.$bvModal.hide('modal-prevent-closing')\n\n    },\n    resetSubCmpk() {\n      this.fscpmk.id = null;\n      this.fscpmk.mingguke = null;\n      this.fscpmk.kodeCpmk = null;\n      this.fscpmk.deskripsi = '';\n      this.fscpmk.indikator = '';\n      this.fscpmk.materi = '';\n      this.fscpmk.bentukAssesment = null;\n      this.fscpmk.namaAssesment = '';\n      this.fscpmk.metode = '';\n      this.fscpmk.luring = '';\n      this.fscpmk.daring = '';\n      this.fscpmk.prosentase = null;\n      this.fscpmk.kodeBloomC = null;\n      this.fscpmk.kodeBloomA = null;\n      this.fscpmk.kodeBloomP = null;\n      this.bloomAWord = \"\";\n      this.bloomPWord = \"\";\n      this.bloomCWord  = \"\";\n    },\n    resetCmpk() {\n      this.fcpmk.id = null;\n      this.fcpmk.kodeCpl = null;\n      this.fcpmk.kodeCpmk= '';\n      this.fcpmk.namaCpmk= '';\n      this.fcpmk.kodeBloomC = null;\n      this.fcpmk.kodeBloomA = null;\n      this.fcpmk.kodeBloomA = null;\n      this.bloomCWordCpmk = '';\n      this.bloomAWordCpmk = '';\n      this.bloomPWordCpmk = '';\n    },\n    onRowSelected(items) {\n      this.selected = items\n    },\n    onRowSelectedBk(items) {\n      this.selectedBk = items\n    },\n    onRowSelectedRps(items) {\n      console.log(items);\n      this.selectedRps = items\n    },\n    onFiltered(filteredItems) {\n      // Trigger pagination to update the number of buttons/pages due to filtering\n      this.totalRows = filteredItems.length\n      this.currentPage = 1\n    },\n    hapusCpl(item) {\n      if (!confirm('Apakah Anda yakin ingin menghapus CPL ini?')) return;\n      var self = this;\n      axios.delete(`/api/${item.id}/cpl`)\n        .then(response => {\n          self.loadTabContent(2);\n        })\n        .catch(error => {\n          console.error('Error hapus CPL:', error);\n        });\n    },\n    hapusBk(item) {\n      if (!confirm('Apakah Anda yakin ingin menghapus Bahan Kajian ini?')) return;\n      var self = this;\n      axios.delete(`/api/${item.id}/bk`)\n        .then(response => {\n          self.loadTabContent(7);\n        })\n        .catch(error => {\n          console.error('Error hapus BK:', error);\n        });\n    },\n    hapusMedia(item) {\n      if (!confirm('Apakah Anda yakin ingin menghapus Media Pembelajaran ini?')) return;\n      var self = this;\n      axios.delete(`/api/${item.id}/media`)\n        .then(response => {\n          self.loadTabContent(3);\n        })\n        .catch(error => {\n          console.error('Error hapus media:', error);\n        });\n    },\n    hapusSumber(item) {\n      if (!confirm('Apakah Anda yakin ingin menghapus Sumber Pustaka ini?')) return;\n      var self = this;\n      axios.delete(`/api/${item.id}/sumber`)\n        .then(response => {\n          self.loadTabContent(4);\n        })\n        .catch(error => {\n          console.error('Error hapus sumber:', error);\n        });\n    },\n    hapusCpmk(item) {\n      if (!confirm('Apakah Anda yakin ingin menghapus CPMK ini?')) return;\n      var self = this;\n      axios.delete(`/api/${item.id}/cpmk`)\n        .then(response => {\n          self.loadTabContent(5);\n        })\n        .catch(error => {\n          console.error('Error hapus CPMK:', error);\n        });\n    },\n    hapusSubCpmk(item) {\n      if (!confirm('Apakah Anda yakin ingin menghapus Sub CPMK ini?')) return;\n      var self = this;\n      axios.delete(`/api/${item.id}/subcpmk`)\n        .then(response => {\n          self.loadTabContent(6);\n        })\n        .catch(error => {\n          console.error('Error hapus Sub CPMK:', error);\n        });\n    },\n    editSubCpmk(item) {\n      axios.get(`/api/subcpmk/${item.id}/detail`)\n        .then(response => {\n          this.fscpmk = response.data;\n          this.$bvModal.show('modal-6');\n        })\n        .catch(error => {\n          console.error(`Error fetching subcpmk detail:`, error);\n        });\n    },\n    copySubCpmk(item) {\n      var self = this;\n      axios.get(`/api/subcpmk/${item.id}/detail`)\n        .then(function (response) {\n          var data = response.data;\n          // Post as new record after the source item's position\n          return axios.post(`/api/${self.rpsId}/scpmk`, {\n            mingguke: data.mingguke,\n            kodeCpmk: data.kodeCpmk,\n            deskripsi: '[Copy] ' + (data.deskripsi || ''),\n            indikator: data.indikator,\n            materi: data.materi,\n            bentukAssesment: data.bentukAssesment,\n            namaAssesment: data.namaAssesment,\n            metode: data.metode,\n            luring: data.luring,\n            daring: data.daring,\n            prosentase: data.prosentase,\n            kodeBloomC: data.kodeBloomC,\n            kodeBloomA: data.kodeBloomA,\n            kodeBloomP: data.kodeBloomP,\n            pustaka: data.pustaka,\n            afterPosition: item.position,\n            isCopy: true\n          });\n        })\n        .then(function () {\n          self.loadTabContent(6);\n        })\n        .catch(function (error) {\n          console.error('Error copying subcpmk:', error);\n          alert('Gagal menyalin Sub CPMK');\n        });\n    },\n    moveSubCpmk(item, direction) {\n      var self = this;\n      axios.put(`/api/subcpmk/${item.id}/reorder`, { direction: direction })\n        .then(function () {\n          self.loadTabContent(6);\n        })\n        .catch(function (error) {\n          console.error('Error reordering subcpmk:', error);\n        });\n    },\n    subcpmkRowClass(item, type) {\n      if (!item || type !== 'row') return '';\n      if (item.isCopy) return 'subcpmk-copy-row';\n      return '';\n    },\n    editCpmk(item) {\n      axios.get(`/api/cpmk/${item.id}/detail`)\n        .then(response => {\n          this.fcpmk = response.data;\n          this.$bvModal.show('modal-5');\n        })\n        .catch(error => {\n          console.error(`Error fetching content for Tab ${tabId}:`, error);\n        });\n    },\n    getKataKerjaC: function(selected) {\n      axios.get(`/api/blooms/${this.fscpmk.kodeBloomC}/detail`)\n        .then(response => {\n          this.bloomCWord = response.data;\n        })\n        .catch(error => {\n          console.error(`Error fetching content for Tab ${tabId}:`, error);\n        });\n    },\n    getKataKerjaA: function(selected) {\n      axios.get(`/api/blooms/${this.fscpmk.kodeBloomA}/detail`)\n        .then(response => {\n          this.bloomAWord = response.data;\n        })\n        .catch(error => {\n          console.error(`Error fetching content for Tab ${tabId}:`, error);\n        });\n    },\n    getKataKerjaP: function(selected) {\n      axios.get(`/api/blooms/${this.fscpmk.kodeBloomP}/detail`)\n        .then(response => {\n          this.bloomPWord = response.data;\n        })\n        .catch(error => {\n          console.error(`Error fetching content for Tab ${tabId}:`, error);\n        });\n    },\n    getKataKerjaCcpmk: function(selected) {\n      axios.get(`/api/blooms/${this.fcpmk.kodeBloomC}/detail`)\n        .then(response => {\n          this.bloomCWordCpmk = response.data;\n        })\n        .catch(error => {\n          console.error(`Error fetching content for Tab ${tabId}:`, error);\n        });\n    },\n    getKataKerjaAcpmk: function(selected) {\n      axios.get(`/api/blooms/${this.fcpmk.kodeBloomA}/detail`)\n        .then(response => {\n          this.bloomAWordCpmk = response.data;\n        })\n        .catch(error => {\n          console.error(`Error fetching content for Tab ${tabId}:`, error);\n        });\n    },\n    getKataKerjaPcpmk: function(selected) {\n      axios.get(`/api/blooms/${this.fcpmk.kodeBloomP}/detail`)\n        .then(response => {\n          this.bloomPWordCpmk = response.data;\n        })\n        .catch(error => {\n          console.error(`Error fetching content for Tab ${tabId}:`, error);\n        });\n    },\n    syncToMoodle() {\n      var self = this;\n      this.syncLoading = true;\n      this.syncResult = null;\n      axios.post(`/api/${this.rpsId}/sync-moodle`)\n        .then(function (response) {\n          self.syncResult = response.data;\n        })\n        .catch(function (error) {\n          if (error.response && error.response.data) {\n            self.syncResult = error.response.data;\n          } else {\n            self.syncResult = { success: false, error: 'Terjadi kesalahan koneksi' };\n          }\n        })\n        .finally(function () {\n          self.syncLoading = false;\n        });\n    },\n  },\n  mounted() {\n    this.loadFirst();\n  }\n};\n</script>\n\n<style src=\"vue-multiselect/dist/vue-multiselect.min.css\"></style>\n<style scoped>\n.tab-loading-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  background: rgba(255, 255, 255, 0.7);\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  z-index: 10;\n  min-height: 200px;\n}\n</style>\n<style>\n.subcpmk-copy-row {\n  background-color: rgba(13, 202, 240, 0.15) !important;\n  border-left: 3px solid #0dcaf0 !important;\n}\n@media (prefers-color-scheme: dark) {\n  .subcpmk-copy-row {\n    background-color: rgba(13, 202, 240, 0.2) !important;\n    color: inherit !important;\n  }\n}\n</style>\n"],"names":[],"sourceRoot":""}*/