Membuat Upload Tugas Menggunakan Script Google Drive

Proses pembelajaran yang dilaksanakan guru / dosen seringkali memberi tugas kepada mahasiswa/siswa dan hasilnya dikirim melalui email atau Whatsapp ataupun medi lainnya. Sebenarnya hal ini sudah biasa dilakukan oleh semua orang, dimana ujung-ujungnya guru/dosen tersebut harus mengunduh satu persatu file yang dikirimkan oleh mahasiswa/siswa. Jika mahasiswa/siswa yang diampu jumlahnya tidak terlalu banyak mungkin tidak masalah, tapi jika jumlahnya banyak dan matakuliah atau matapelajaran yang berbeda-beda, ini akan menjadikan pekerjaan yang kurang efektif.

Kita sebagai pendidikan akan mengalami kesulitan melihat ini termasuk tugas apa punya siapa. Nah, dengan memanfaatkan aplikasi yang disediakan oleh Google Drive merupakan salah satu cara untuk memanajemen file tugas. Data dan file tugas yang dikirim oleh mahasiswa akan langsung masuk ke Google sheet dan drive lewat Form Upload seperti contoh tampilan dibawah ini.

Tampilan aplikasi upload tugas

Tampilan aplikasi upload tugas

FIle yang sudah diupload mahasiswa

FIle yang sudah diupload mahasiswa

FIle Excel/Spreadsheet sebagai tabel daftar upload

FIle Excel/Spreadsheet sebagai tabel daftar upload

Dengan model manajemen file seperti ini kita akan lebih mudah melihat file yang sudah diupload oleh siswa atau mahasiswa. Karena dari file Excel atau Spreadsheet yang ada sudah menunjukkan link file, dan file tertata rapi dalam satu folder dalam google drive, beda dengan di email yang kita akan kebingungan mencari file. Selain itu file yang diupload lebih besar dari kapasitas file email yang hanya 25MB.

 Bagaimana caranya? Nah berikut adalah langkah-langkahnya :

  1. Login dan masuk ke Google Drive dan buat folder baru, misal nama foldernya “Tugas Matakuliah blablabla”.

2. Masuk kedalam folder yang baru saja dibuat dan buatlah file sheet baru, misal nama filenya “Upload Tugas”

3. Buka kembali file sheet yang baru saja dibuat lalu buat Header sesuai kolom yang akan kita isikan

pastikan kolom pertama (A) berisi waktu atau timestamp, yaitu untuk isian otomatis upload

4. Kemudian pilih file menu Tool > Script editor

5. Nama Project Script bisa diubah atau default juga tidak masalah

6. Ubah isi script code.gs atau kode.gs seperti dibawah ini:

var SPREADSHEET_FILE_ID = '1tDPX_GW8g62EF7FrfzgsgiqLAeyBUfyL9U';
var SHEET_NAME_TO_WRITE_DATA_TO = "Sheet1";
var folderId = "1mjMXkldNRr8X1gt_TDLpEzY_W";
var ADD_TIMESTAMP = true;
var ADD_IMAGE_URLS_TO_SHEET = true;function doGet() {
var template = HtmlService.createTemplateFromFile('index');return template.evaluate()
.setTitle('Upload Tugas Mahasiswa')
.setSandboxMode(HtmlService.SandboxMode.IFRAME);
};

untuk file ID silakan ganti dengan file ID Anda yang ada di file seperti gambar di bawah ini

untuk folder ID silakan ganti dengan folder ID Anda yang ada di file seperti gambar di bawah ini

untuk nama sheet (Sheet1) sesuaikan dengan nama sheet yang kita gunakan layaknya sheet dalam file excel pada umumnya

7. Buat file Html baru melalui menu File > New > Html file. Beri nama “CSS_Generic.html” dan ubah isi scriptnya seperti dibawah ini:

<style>
.spinner {position: absolute;left:42%;top=35%;}
</style>

8. Buat file Html baru melalui menu File > New > Html file. Beri nama “CSS_Main_Form.html” dan ubah isi scriptnya seperti dibawah ini:

<style type="text/css">

#msgToUsr {
position: absolute;
left: 30%;
width: 40%;
background-color: white;
border: 2px solid red;
text-align: center;
display:none;
}

#titleOfForm {
display: block;
margin-left: auto;
margin-right: auto;
margin-bottom: 6px;
width:488px;
height:40px;
border: solid 1px lightgray;
border-radius: 5px;
background: #73AD21;
padding: 12px;
text-align:center;
}

img {
display: block;
margin-left: auto;
margin-right: auto;
width:500px;
height:170px;
}

form {
width:450px;
padding:30px;
margin: auto;
background: #FFF;
border-radius: 10px;
-webkit-border-radius:10px;
-moz-border-radius: 10px;
box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.13);
-moz-box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.13);
-webkit-box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.13);
}

h2 {
width:450px;
padding:30px;
margin: auto;
margin-top: 5px;
margin-bottom: 10px;
text-align: center;
border-radius: 10px;
background: #FF8500;
color: #fff;
box-shadow: 1px 1px 4px #DADADA;
-moz-box-shadow: 1px 1px 4px #DADADA;
-webkit-box-shadow: 1px 1px 4px #DADADA;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}

h1 {
background: #2A88AD;
padding: 20px 30px 15px 30px;
margin: -30px -30px 30px -30px;
border-radius: 10px 10px 0 0;
-webkit-border-radius: 10px 10px 0 0;
-moz-border-radius: 10px 10px 0 0;
color: #fff;
text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.12);
font: normal 30px 'Bitter', serif;
-moz-box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.17);
-webkit-box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.17);
box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.17);
border: 1px solid #257C9E;
}

h1 > span {
display: block;
margin-top: 2px;
font: 13px Arial, Helvetica, sans-serif;
}

label {
display: block;
font: 13px Arial, Helvetica, sans-serif;
color: #888;
margin-bottom: 15px;
}

input[type="text"],
input[type="email"],
input[type="file"],
textarea,
select {
display: block;
box-sizing: border-box;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
width: 100%;
padding: 8px;
outline: none;
border: 1px solid #B0CFE0;
-webkit-transition: all 0.30s ease-in-out;
-moz-transition: all 0.30s ease-in-out;
-ms-transition: all 0.30s ease-in-out;
-o-transition: all 0.30s ease-in-out;
}

section{
font: normal 20px 'Bitter', serif;
color: #2A88AD;
margin-bottom: 5px;
}

section span {
background: #2A88AD;
padding: 5px 10px 5px 10px;
position: absolute;
border-radius: 50%;
-webkit-border-radius: 50%;
-moz-border-radius: 50%;
border: 4px solid #fff;
font-size: 14px;
margin-left: -45px;
color: #fff;
margin-top: -3px;
}

input[type="button"],
input[type="submit"]{
background: #2A88AD;
padding: 8px 20px 8px 20px;
border-radius: 5px;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
color: #fff;
text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.12);
font: normal 30px 'Bitter', serif;
-moz-box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.17);
-webkit-box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.17);
box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.17);
border: 1px solid #257C9E;
font-size: 15px;
}
input[type="button"]:hover,
input[type="submit"]:hover{
background: #2A6881;
-moz-box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.28);
-webkit-box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.28);
box-shadow: inset 0px 2px 2px 0px rgba(255, 255, 255, 0.28);
}

</style>

9. Buat file google script baru melalui menu File > New > Script file. Beri nama “GS_Process_Data.gs” dan ubah isi scriptnya seperti dibawah ini:

function processForm(theForm) {
var allTheData,doc,fileBlob,folder,sheet,targetRange,template;
var npm,name,handphone,email,mkkelas,jenis;
var fileUrl;
var arrayOfNamesToWriteToSS,i,L,outerArray,innerArray,thisKey,TS;
//Logger.log(theForm);

arrayOfNamesToWriteToSS = ['nim','nama','jenis'];
L = arrayOfNamesToWriteToSS.length;

fileBlob = theForm.myFile1;


Logger.log(fileBlob)


if (folderId) {
folder = DriveApp.getFolderById(folderId);
} else {
folder = DriveApp.getRootFolder();
};

if (fileBlob.name) {doc = folder.createFile(fileBlob); fileUrl = doc.getUrl();};

template = HtmlService.createHtmlOutputFromFile('HTML_Feedback').getContent();

allTheData = "";
innerArray = [];

if (ADD_TIMESTAMP) {
TS = new Date();
innerArray.push(TS);
};

for (i=0;i<L;i+=1) {
thisKey = arrayOfNamesToWriteToSS[i];
allTheData = allTheData + theForm[thisKey] + " <br>";
innerArray.push(theForm[thisKey]);
};

outerArray = [];
outerArray.push(innerArray);

//Logger.log('theForm.name: ' + theForm.name);
template = template.replace('11111_PutTheDataHere_22222',allTheData);

if (ADD_IMAGE_URLS_TO_SHEET) {
if (fileUrl) innerArray.push(fileUrl);

};

if (!SPREADSHEET_FILE_ID) {return ['err','No Spreadsheet ID',template]};

sheet = SpreadsheetApp.openById(SPREADSHEET_FILE_ID).getSheetByName(SHEET_NAME_TO_WRITE_DATA_TO);
sheet.appendRow(innerArray);

return template;
}

untuk yang diwarna merah disesuaikan dengan kebutuhan kita

10. Buat file Html dengan nama “HTML_Body.html” dan ganti isi scriptnya seperti dibawah ini :

<div id="formDiv">
<!-- Form div will be hidden after form submission -->
<!-- <img src=""> -->

<div id="msgToUsr"></div>

<form id="myForm">
<h1>Form Unggah Tugas Mahasiswa Matakuliah Teknologi Pembelajaran Fisika<span>Isi semua data dengan benar.</span></h1>

Nomor Induk Mahasiswa : <input type="text" name="nim" onchange="clearIt(this)" placeholder="Tulis NIM"/><br/>
Nama Mahasiswa : <input type="text" name="nama" onchange="clearIt(this)" placeholder="Tulis Nama Lengkap Mahasiswa"/><br/>

Jenis Tugas : <select name="jenis" onchange="clearIt(this)">
<option>Individu ke-1</option>
<option>Individu ke-2</option>
<option>Individu ke-3</option>
<option>Individu ke-4</option>
<option>Individu ke-5</option>
<option>Kelompok ke-1</option>
<option>Kelompok ke-2</option>
</select><br/>


Upload SK/Piagam/Sertifikat (pdf/docx/xlsx/jpg/dll) : <input type="file" name="myFile1" onchange="clearIt(this)"/><br/>

<input type="button" value="Kirim" onmouseup="submitForm(this.parentNode)" /><br/>
</form>

</div>

<div id="inProgress" style="display: none;">
<!-- Progress starts hidden, but will be shown after form submission. -->
Proses upload. Mohon ditunggu sebentar dengan sabar :)...
</div>

<div id="output">
<!-- Blank div will be filled with "Thanks.html" after form submission. -->
</div>

Judul form (warna merah dapat disesuaikan dengan kebutuhan

11. Buat file html dengan nama “HTML_Feedback.html” dan ganti isi scriptnya seperti dibawah ini :

<div>
<h2>.:: Unggahan Data Berhasil ::.<br><br/>Terima kasih telah unggah data Tugas.</h2>
<br><br/>Ttd. <br/>Dosen Pengampu Matakuliah <br/><b>(HM Rohmadi)</b>
</div>

12. Buat file html dengan nama “JS_Library.html” dan ganti isi scriptnya seperti dibawah ini :

<script>
window.AlanWells_shwSpnr = function(a,b) {
//console.log('a: ' + a)
AlanWells_displayinline(a);
var daSpinHtml = '<div><img src="http://www.fairfieldelections.com/images/load_fancy.gif" alt="Smiley face" height="42" width="42"></div>';
AlanWells_inHtml(a,daSpinHtml);
};

window.AlanWells_hideSpnr = function(a,b) {
AlanWells_inHtml(a,"");//If spinner was displayed, make sure it gets turned off
AlanWells_hide(a);
};

window.AlanWells_displayinline = function(a) {
document.getElementById(a).style.display = "inline";
};

window.AlanWells_inHtml = function(a,b) {
document.getElementById(a).innerHTML = b;
};

window.AlanWells_hide = function(a) {
document.getElementById(a).style.display = "none";
};
</script>

13. Buat file html dengan nama “JS_Main_Form.html” dan ganti isi scriptnya seperti dibawah ini :

<script>
window.clearIt = function(thisEl) {
document.getElementById('msgToUsr').style.display = 'none';
thisEl.style.backgroundColor = "";
};

window.submitForm = function(myForm) {
var key,value,requiredList=[],nameName,thisEl,errElmt,inputType,die;
die = false;

requiredList = ['npm','name','myFile1'];//This is a list of the names of questions that must be filled out

for (key in myForm) {
/*console.log('key: ' + key);
console.log('value: ' + myForm[key]);

console.log('value: ' + myForm[key].value);
console.log(myForm[key].value === "");
*/
thisEl = myForm[key];
if (thisEl===null) continue;

nameName = thisEl.name;
if (requiredList.indexOf(nameName) === -1) {continue;};//If the name is not in the required list

value = thisEl.value;
inputType = thisEl.type;


/*console.log('inputType: ' + inputType);
console.log('value: ' + value);
console.log('name: ' + nameName);

console.log(value === "");
*/
if (value === "") {
//console.log('inside if block')
//console.log(requiredList.indexOf(nameName) === -1);

if (requiredList.indexOf(nameName) === -1) {continue;};//If the name is not in the required list
die = true;
//then it's not required, keep on checking other entries
toggle_visibility('inProgress');
toggle_visibility('formDiv');

thisEl.style.backgroundColor = "red";//Turn the background red
thisEl.focus();//Move focus to the element with missing data
window.scrollTo(0,0);//Scroll to the top
errElmt = document.getElementById('msgToUsr');
errElmt.textContent = "Semua data harus diisi lengkap! klik pesan ini untuk menutup";
errElmt.style.display = 'inline-block';
errElmt.style.top = "45%";
errElmt.addEventListener("click", function(){
this.style.display = "none";});
};
};

//console.log('right before google.script.run');
//console.log(die);

if (die) return;

toggle_visibility('formDiv');
toggle_visibility('inProgress');
AlanWells_shwSpnr('idSpnr');

google.script.run
.withSuccessHandler(updateOutput)
.processForm(myForm)

};

// Javascript function called by "submit" button handler,
// to show results.
function updateOutput(dataReturned) {
var html,outputDiv;

console.log('dataReturned: ' + dataReturned);
console.log('typeof dataReturned: ' + typeof dataReturned);

if (typeof dataReturned === 'object') {
html = "<div>Data was not saved to spreadsheet</div><div>No Spreadsheet ID is set</div>" + dataReturned[2];
} else {
html = dataReturned;
};
toggle_visibility('inProgress');
outputDiv = document.getElementById('output');
outputDiv.innerHTML = html;
AlanWells_hideSpnr('idSpnr');
}

// From blog.movalog.com/a/javascript-toggle-visibility/
function toggle_visibility(id) {
var e;
//console.log('toggle_visibility ran' + id);

e = document.getElementById(id);
if(e.style.display !== 'none')//Modified this line
e.style.display = 'none';
else
e.style.display = 'block';
}

/* I modified the code for the function named toggle_visibility

if(e.style.display !== 'none')//Modified this line

Was:

if(e.style.display === 'block')
The style could be many different settings. If it's inline for example, then that would break the code.
But if it's !== "none", then if it's anything but none, then it's obviously being displayed.
*/
</script>

14. Buat file html dengan nama “index.html” dan ganti isi scriptnya seperti dibawah ini :

<!DOCTYPE html>
<html>
<head>
<base target="_top">
<link href='http://fonts.googleapis.com/css?family=Bitter' rel='stylesheet' type='text/css'>
<!-- Use a templated HTML printing scriptlet to import stylesheet -->
<?!= HtmlService.createHtmlOutputFromFile('CSS_Main_Form').getContent(); ?>
<?!= HtmlService.createHtmlOutputFromFile('CSS_Generic').getContent(); ?>
</head>
<body>
<?!= HtmlService.createHtmlOutputFromFile('HTML_Body').getContent(); ?>
</body>

<!-- Use a templated HTML printing scriptlet to import JavaScript. -->
<?!= HtmlService.createHtmlOutputFromFile('JS_Main_Form').getContent(); ?>
<?!= HtmlService.createHtmlOutputFromFile('JS_Library').getContent(); ?>

<div id="idSpnr" class="spinner"></div>
</html>

15. Silakan Pilih File->Save All atau File–>Simpan Semua. Maka tampilan akhir penambahan script seperti dibawah ini :

14. Kemudian klik file menu Publikasikan-> Terapkan sebagai Aplikasi Web, akan tampil seperti dibawah ini:

15. Isikan sesuai keterangan di gambar di bawah, lalu pilih Deploy.

16. berikutnya muncul link upload tugas:

17. Silakan dicoba, jika diperlukan hak akses menulis file silakan ijinkan agar daapt upload tugas.

18. Untuk memperpendek link dapat menggunakan http://s.id atau http://gg.gg atau htp://bit.ly dan lainnya

19. Selamat form upload tugas sudah bisa digunakan

20. Catatan: untuk memperoleh space google drive unlimited gunakan GSuite for Education menggunakan domain sekolah/Perguruan Tinggi Anda.

42 comments

Lompat ke formulir komentar

    • Ega Bekti on 14 Juli 2020 at 21:40
    • Balas

    setelah saya mengikut tahap demi tahap sampai selesai, terjadi error ketika membuka form dengan pemberitahuan “Script function not found: doGet”, sepertinya ada command yag kurang di bagian scriptnya. Bisa tolong diperbaiki dibagian mana comman “doGet” seharusnya disimpan ?

    1. coba dicek lagi, apakah ada yang tertinggal?

    • Rezam on 5 September 2020 at 08:32
    • Balas

    Saya sudah coba mengikuti langkah2 diatas, namun file yg berhasil teman2 upload ketika saya cek file pdf nya kosong, apakah ada solusinya?

    1. coba dicek lagi apakah sudah benar scriptnya

    • luqman on 28 September 2020 at 14:25
    • Balas

    saya sudah berhasi, namun pas klik menu kirim kok tidak bisa terupload ya kenapa ya?

    1. cek perijinan folder dan id file dan foldernya

    • adrhie on 26 November 2020 at 09:39
    • Balas

    min user lain klo mau akses harus log in ya dengan akun google

    1. tinggal settingannya, apakah perlu mengumpulkan email atau tidak

    • kara on 11 Januari 2021 at 17:37
    • Balas

    spreadsheetnya kok gak nyambung gan

    1. cek lagi nama sheet, id file dan id folder di drivenya

    • kara on 12 Januari 2021 at 14:57
    • Balas

    berhasil tp isi file corupt kenapa ya??

    1. ada ijin di folder yang blm dibuka, cek lagi script yang ada dan ijin menulis di folder yang dituju

        • Fuad Insan Muttaqin on 27 Januari 2021 at 13:09
        • Balas

        saya juga sudah berhasil kang, tapi corrupt, script mana ya yg perlu dicek? mohon maaf sebelumnya

        1. coba dicek lagi izin folder dan script nya

    • Azid Zainuri on 15 Januari 2021 at 21:27
    • Balas

    apakah untuk form nya diluar layanan script google, jadi kita buat form html di website kita sendiri misalnya?

    1. rasanya bisa saja, pernah mencoba, tp untuk upload masih gagal

    • Octo Bagas Wicaksono on 26 Januari 2021 at 08:50
    • Balas

    sama saya juga sepeeti itu mas

    1. cek lagi izin menulis di folder

    • Hendry Ikram on 14 Juni 2021 at 17:14
    • Balas

    Saya sudah coba mengikuti langkah2 diatas, namun file yg berhasil upload ketika saya cek file nya kosong, apakah ada solusinya?

    1. saya coba lagi dulu, dimana kesalahannya

    • Hendry Ikram on 16 Juni 2021 at 08:20
    • Balas

    Saya sudah coba mengikuti langkah2 diatas,
    namun file yg berhasil di upload ketika saya cek filenya kosong,
    apakah ada solusinya?

    1. baik,saya verifikasi lagi scriptnya

    • yusri on 17 Juli 2021 at 02:52
    • Balas

    Saya sudah coba mengikuti langkah2 diatas, namun file yg berhasil teman2 upload ketika saya cek file pdf nya kosong, apakah ada solusinya?

    1. nah coba saya cek lagi scriptnya, saya mencoba aman saja

    • Pengguna on 28 Juli 2021 at 16:54
    • Balas

    script sudah sama dan berjalan. upload juga lancar tetapi giliran file di download file nya korupt. mohon solusinya bang. perizinan folder juga sudah di buat umum

    1. baik, saya coba verifikasi scriptnya dulu

  1. masalasah yang sama file nya kosong coba cek https://docs.google.com/spreadsheets/d/18yytkxdNbwvn-3E02bVigfHncNoSBduYkrKhtHCYTwo/edit?usp=sharing

    1. baiklah, sebentar saya cek permasalahnnya,..terima kasih

    • kartono on 25 Oktober 2021 at 09:55
    • Balas

    untuk beberapa upload gmn caranya

    1. bisa dibuatkan formya dengan beberapa form upload, copy bagian upload file, namun pastikan nama berbeda, misal upload1, upload2 dst

    • hma on 1 Maret 2022 at 19:47
    • Balas

    mas, apakah ada menyematkan (embed) form tersebut? Dan bagaimana cara mengumpulkan data (mis email) dari spreadsheet tanpa membuat pertanyaanya?

    1. sepengetahuan saya tidak mau disematkan, karena ada SSL yang menolak

    • Himaladin on 7 Maret 2022 at 10:29
    • Balas

    Beberapa pertanyaan saya:
    1. Bagaimana form ini dapat disematkan (embed) ?
    2. Bagaimana jika saya ingin mengumpulkan email user tanpa melalui input field?
    Terima kasih

    1. sepengetahuan saya tidak mau disematkan, karena ada SSL yang menolak, dan blm bisa mengumpulkan email tanpa input field

    • Himaladin on 14 Maret 2022 at 20:04
    • Balas

    Terima kasih atas desain yang bagus dari form anda.
    Saya berhasil menyematkan dengan menambahkan “.setXFrameOptionsMode(HtmlService.XFrameOptionsMode.ALLOWALL);”
    di bawah setSandboxMode.

    1. terima kasih telah mampir dan terima kasih juga sudah memberikan tambahan pengetahuan bagi saya..

      • rasel on 16 September 2022 at 15:29
      • Balas

      Fungsi skrip tidak ditemukan: doGet ini yang muncul, kenapa ya mas

      1. cek lagi penulisannya, kemungkinan ada yang salah atau terlewat

    • ZFS on 28 Juni 2022 at 14:34
    • Balas

    Halo Kang, terimakasih banyak sudah share, sangat bermanfaat dan sudah bisa saya pakai untuk segala keperluan. Hanya mau tanya, ketika membuka URL deployment, ada notifikasi bahwa aplikasi belum terverifikasi oleh Google. Apakah aman Kang? Mohon penjelasannya, punten saya awam hehe

    1. insyaallah aman saja, saya sudah pakai lama

    • ime on 12 September 2023 at 15:31
    • Balas

    sore Bang,
    Terimakasih atas form uploadnya.
    NAMUN ketika saya tes, lama sekali untuk upload data dan file nya dan data di spreadsheet nya selalu kosong meskipun upload filenya ada atau berhasil.
    Mohon info ya harus di perbaiki disebelah mananya?

    1. itu kemungkinan karena jaringan saja yang lama, atau kuota google drive penuh

Tinggalkan Balasan

Your email address will not be published.

*

Situs ini menggunakan Akismet untuk mengurangi spam. Pelajari bagaimana data komentar Anda diproses.

Translate »