-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCommon.ts
More file actions
113 lines (102 loc) · 3.07 KB
/
Common.ts
File metadata and controls
113 lines (102 loc) · 3.07 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import { ISubscribedCourse, ISubscriptionEntity, IWishlistedCourse, IWishlistEntity } from './Types';
function prepareSheet(sheetName: string): GoogleAppsScript.Spreadsheet.Sheet {
const spreadSheet = SpreadsheetApp.getActive();
const oldSheet = spreadSheet.getSheetByName(sheetName);
let newSheet: GoogleAppsScript.Spreadsheet.Sheet;
if (oldSheet != null) {
const index = oldSheet.getIndex();
spreadSheet.deleteSheet(oldSheet);
newSheet = spreadSheet.insertSheet(sheetName, index - 1);
} else {
newSheet = spreadSheet.insertSheet(sheetName);
}
newSheet.setFrozenRows(1);
return newSheet;
}
function prepareHeader(sheet: GoogleAppsScript.Spreadsheet.Sheet, header: any[]) {
appendRow(sheet, header, 1);
}
function appendRow(sheet: GoogleAppsScript.Spreadsheet.Sheet, rows: any[], row: number) {
const newData = [];
newData.push(rows);
sheet.getRange(row, 1, 1, rows.length).setValues(newData);
}
function getToken() {
const properties = PropertiesService.getUserProperties();
return properties.getProperty('token');
}
function setToken(token: string) {
const properties = PropertiesService.getUserProperties();
properties.setProperty('token', token);
}
function checkTokenExistence() {
const token = getToken();
if (token !== null) { return; }
throw (getText('bearer_token_not_exist'));
}
function mapToSubscriptionEntity(course: ISubscribedCourse): ISubscriptionEntity {
return {
completion_ratio: course.completion_ratio,
estimated_content_length: course.estimated_content_length,
is_draft: course.is_draft,
last_update_date: course.last_update_date,
num_lectures: course.num_lectures,
num_reviews: course.num_reviews,
num_subscribers: course.num_subscribers,
rating: course.rating,
title: course.title,
url: course.url,
};
}
function getSubscriptionRow(entity: ISubscriptionEntity) {
return [
entity.title,
entity.url,
entity.num_lectures,
entity.estimated_content_length,
entity.last_update_date,
entity.num_subscribers,
entity.num_reviews,
entity.rating,
entity.completion_ratio,
entity.is_draft,
];
}
function mapToWishlistEntity(course: IWishlistedCourse): IWishlistEntity {
return {
estimated_content_length: course.estimated_content_length,
last_update_date: course.last_update_date,
num_published_lectures: course.num_published_lectures,
num_reviews: course.num_reviews,
num_subscribers: course.num_subscribers,
price: course.discount?.price?.amount || course.price_detail?.amount,
rating: course.rating,
title: course.title,
url: course.url,
};
}
function getWishlistRow(entity: IWishlistEntity) {
return [
entity.title,
entity.url,
entity.num_published_lectures,
entity.estimated_content_length,
entity.last_update_date,
entity.num_subscribers,
entity.num_reviews,
entity.rating,
entity.price,
];
}
export {
appendRow,
checkTokenExistence,
getSubscriptionRow,
getWishlistRow,
getToken,
mapToSubscriptionEntity,
mapToWishlistEntity,
prepareHeader,
prepareSheet,
setToken,
};