-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstaspaces.pug
138 lines (115 loc) · 5.04 KB
/
instaspaces.pug
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
136
137
138
---
title: Instagram Paragraph Whitespaces
---
h1 Instagram Paragraph Whitespaces
p.text-center: a(href='https://youtu.be/osFm3XstkDo') Tutorial Video on YouTube
p Making paragraphs work on Instagram is a pain. You can't have whitespaces at the end of any line, empty lines have to have some kind of character (otherwise they get removed), and it's really easy to mess these things up.
p This mini tool automatically removes the whitespaces at the end of each line and puts invisble characters into the empty lines. This way you have nice looking paragraphs! #YAY
style(media="screen" type="text/css").
.green {
background-color: green;
}
.red {
background-color: red;
}
.notifyjs-corner {
left: 0 !important;
right: 0 !important;
}
.notifyjs-corner .notifyjs-wrapper, .notifyjs-corner .notifyjs-container {
width: 80vw !important;
text-align: center;
margin: 3px auto !important;
}
.notifyjs-bootstrap-base {
background-image: none !important;
}
textarea {
padding: .5rem;
}
div(style='width: 100%; margin: .5rem auto;')
textarea#txtDescription(name='' placeholder="Write Instagram Description here. \
Once you're done, hit that `Make Whitespaces` button. \
Now you can copy the text and bring it back to Instagram! \
Enjoy ❤" oninput='return changeTextarea();' style='width:100%; height: 40vh; margin: 1rem 0 2rem;')
#changedStatus(style='line-height: 3rem; font-weight: bold;text-align: center;') Click "Make Whitespaces" to transform.
#characterCount(style='line-height: 3rem; font-weight: bold;text-align: center;') 0 / 2200
.side-by-side
button#btnChange.btn.btn-block(onclick='return changeText();' type='') Make Whitespaces
button#btnCopy.btn.btn-block(data-clipboard-target='#txtDescription' type='') Copy to Clipboard
script(src="https://cdn.jsdelivr.net/npm/jquery@3.5/dist/jquery.min.js")
script(src="https://cdn.jsdelivr.net/npm/clipboard@2.0/dist/clipboard.min.js")
script(src="https://cdn.jsdelivr.net/npm/notifyjs-browser@0.4/dist/notify.min.js")
script(type="text/javascript").
console.log('Loading Instagram Whitespace App');
$.notify.defaults({
position: 'top center',
});
const iOS = ['iPad Simulator', 'iPhone Simulator', 'iPod Simulator', 'iPad', 'iPhone', 'iPod'].indexOf(navigator.platform) >= 0;
const changeStatus = document.getElementById("changedStatus");
const textarea = document.getElementById('txtDescription');
const clipboard = new ClipboardJS('#btnCopy', {});
let statusTextarea = false;
clipboard.on('success', function(e) {
console.info('Action:', e.action);
console.info('Text:', e.text);
console.info('Trigger:', e.trigger);
if (statusTextarea == true) {
$.notify("Copied to clipboard!", 'success');
} else {
$.notify("Copied without transformation.", 'warn')
}
e.clearSelection();
});
clipboard.on('error', function(e) {
$.notify("Could not copy text, copy manually!", "error");
console.error('Action:', e.action);
console.error('Trigger:', e.trigger);
});
const changeTextarea = () => {
console.log('called changeTextarea');
changeStatus.innerHTML = "Changed text, click again to update.";
changeStatus.classList.remove("green");
changeStatus.classList.add("red");
statusTextarea = false;
characterCount.innerHTML = `${makeWhitespaces(textarea.value).length}/ 2200`
};
const changeText = () => {
console.log('called changeText');
let text = textarea.value.trim();
let textNew = (text.length == 0) ? '' : makeWhitespaces(text);
textarea.value = textNew;
statusTextarea = true;
$.notify("Updated Whitespaces for Instagram.", 'success');
changeStatus.innerHTML = "Updated Whitespaces for Instagram.";
changeStatus.classList.add("green");
changeStatus.classList.remove("red");
};
const makeWhitespaces = (text) => {
text = text.trim(); // remove all empty lines at beginning and end
let lines = text.split('\n'); // for singular processing
let textNew = '';
let previousEmpty = false; // remember so we can skip all following empty lines
for(let i=0, length1=lines.length; i < length1; i++) {
let line = lines[i].trim();
if (previousEmpty && line.length==0) {
// skip second empty line
} else {
previousEmpty = false;
if (line.length == 0) {
// line = '⠀⠀⠀⠀⠀⠀⠀⠀⠀'; // replace empty line with special white space
line = '⠀⠀'; // replace empty line with special white space
previousEmpty = true; // remember so we can skip the following empty lines
}
textNew += line;
textNew += '\n';
}
}
textNew = textNew.trim(); // trim all empty lines at beginning and end
console.log(textNew); // output for workflow
return textNew;
}
div.content.feedback
p Any issues? Email me #[a(href='mailto:team@ChrisSpiegl.com?subject=Instaspaces Problem') team@ChrisSpiegl.com].
p Would like to support me in creating more tools and services like this?
p: a(href='/patron') Buy me a Tea&Cookie