-
Notifications
You must be signed in to change notification settings - Fork 1
/
index.html
135 lines (127 loc) · 4.39 KB
/
index.html
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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
<!doctype html>
<!--
* HTML Index file for md-editor
*
* @author Prahlad Yeri<[email protected]>
* @license Apache-2.0
* @date
* created 2020-08-01
* Change History:
* 2020-11-26: Got rid of unused elements, created git repo.
* 2024-10-19: Updated footer text.
-->
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, width=device-width, shrink-to-fit=no">
<title>Markdown Editor 1.0</title>
<link rel="stylesheet" href="static/css/external/font-awesome/css/all.min.css">
<link rel="stylesheet" href="static/css/external/bootstrap.min.css">
<link rel="stylesheet" href="static/css/app.css">
</head>
<body>
<style>
.header-label {
font-size: 22px;
font-family: verdana;
}
</style>
<div class='container'>
<div class='row'>
<div id="mainContainer" class='col-md-10 ml-auto mr-auto'>
<h1 class='header-label'>Markdown Editor 1.0</h1>
<!-- Nav tabs -->
<ul id='navCompose' class="nav nav-tabs nav-tabs-justified ">
<li class="nav-item">
<a class="nav-link active" data-toggle="tab" href="#blocMarkdown">Markdown</a>
</li>
<li class="nav-item">
<a class="nav-link " data-toggle="tab" href="#blocHtml">HTML</a>
</li>
<li class="nav-item">
<a class="nav-link " data-toggle="tab" href="#blocPreview">Preview</a>
</li>
<li class="ml-auto">
<button class="btn btn-success btn-sm" id="btnCopyToClipboard">Copy to clipboard</button>
</li>
</ul>
<div style="height:4px;"></div>
<div style="height:4px;"></div>
<!-- Tab panes -->
<div class="tab-content">
<div class="tab-pane container active" id="blocMarkdown">
<textarea id="txtMarkdown" class='form-control' rows="20" cols="80"># start writing some text</textarea>
</div>
<div class="tab-pane container fade" id="blocHtml">
<textarea readonly id="txtHtml" class='form-control' rows="20" cols="80"></textarea>
</div>
<div class="tab-pane container fade" id="blocPreview">
<div id='divPreview'></div>
</div>
</div>
</div>
<div class='footer col-md-10 ml-auto mr-auto text-center'>Copyright(c) 2024 <a href="https://prahladyeri.github.io">Prahlad Yeri</a>. This work is open source and licensed under Apache-2.0. <a href="https://github.com/prahladyeri/md-editor">View source on Github</a></div>
</div>
</div>
<script>
function copyToClipboard (text) {
if (navigator.clipboard) { // default: modern asynchronous API
return navigator.clipboard.writeText(text);
} else if (window.clipboardData && window.clipboardData.setData) { // for IE11
window.clipboardData.setData('Text', text);
return Promise.resolve();
} else {
// workaround: create dummy input
const input = h('input', { type: 'text' });
input.value = text;
document.body.append(input);
input.focus();
input.select();
document.execCommand('copy');
input.remove();
return Promise.resolve();
}
}
window.addEventListener("DOMContentLoaded", function(){
var converter = new Markdown.Converter();
$("#btnCopyToClipboard").click(function(){
var txt = $("#navCompose .nav-link.active").text();
switch(txt) {
case "Markdown":
copyToClipboard($("#txtMarkdown").text());
alert("Markdown text copied to clipboard.");
break;
case "HTML":
copyToClipboard($("#txtHtml").text());
alert("HTML code copied to clipboard.");
break;
case "Preview":
copyToClipboard($("#divPreview").html());
alert("HTML code copied to clipboard.");
break;
}
});
$("#navCompose .nav-link").click(function(){
console.log("clicked!");
var txt = $(this).text();
//console.log('txt:', txt);
if (txt == 'HTML') {
//console.log('now converting:', txt);
var html = converter.makeHtml($("#txtMarkdown").val());
$("#txtHtml").text(html);
}
else if (txt == "Preview") {
var html = converter.makeHtml($("#txtMarkdown").val());
$("#divPreview").html(html);
}
});
});
</script>
<!-- ... -->
<script src="static/js/external/jquery-1.11.1.min.js"></script>
<script src="static/js/external/popper-1.16.0.min.js"></script>
<script src="static/js/external/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/pagedown/1.0/Markdown.Converter.min.js"></script>
<!-- <script src="https://unpkg.com/turndown/dist/turndown.js"></script> -->
</body>
</html>