Subversion Repositories munaweb

Rev

Rev 15 | Rev 19 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 - 1
<!DOCTYPE html>
2
<html lang="en">
3
 
4
<head>
5
    <title>eBay Listing Upload</title>
6
    <meta charset="UTF-8">
7
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
8
    <link rel="shortcut icon" href="favicon.ico" type="image/x-icon">
9
    <link rel="icon" href="favicon.ico" type="image/x-icon">
10
 
11
    <link rel="stylesheet" href="https://www.w3schools.com/w3css/4/w3.css">
12
    <link href="https://fonts.googleapis.com/css?family=Lato" rel="stylesheet">
13
    <link rel="stylesheet" href="css/style.css">
14
    <script src="js/XMLWriter.js"></script>
15
    <script src="js/lodash.min.js"></script>
16
    <script src="js/muna-tools.js"></script>
17
</head>
18
 
19
<body onload="return initConfig();">
20
    <div class="w3-main">
21
        <div class="w3-container w3-padding w3-margin w3-card-4">
22
            <div class="w3-container w3-gray" style="height:100px">
23
                <img class="w3-image" src="images/MUNA%20-%20Logo%20100x100.png" alt="MUNA Trading Logo" style="height:100px">
24
                <p id="connected" class="w3-xxlarge w3-right">eBay Listing Upload
25
                    <input id="login" type="button" class="w3-btn w3-large w3-green w3-margin w3-round-large w3-ripple w3-right w3-hide" onclick="eBayLogin();" value="Login" />
26
                </p>
27
            </div>
28
 
29
            <div class="w3-row">
30
                <div>
31
                    <form id="searchForm" class="w3-container w3-light-grey w3-padding w3-small">
32
                        <div class="w3-container w3-card-2 w3-cell w3-padding">
6 - 33
                            <input id="startButton" type="button" class="w3-btn w3-large w3-red w3-margin w3-round-large w3-ripple" onclick="uploadListings();" value="Start" />
34
                            <p id="numberOfListings" class="w3-right"></p>
2 - 35
                        </div>
36
                    </form>
37
                </div>
38
                <div id="progressBarDiv" class="w3-container w3-padding w3-margin w3-card-4 w3-hide">
39
                    <h2 id="progressBarHeader"></h2>
40
                    <div class="w3-light-grey">
41
                        <div id="progressBar" class="w3-container w3-green w3-center" style="width:0%">0%</div>
42
                    </div>
43
                </div>
44
                <div id="logging" class="w3-container w3-padding"></div>
45
                <div id="results" class="w3-container w3-padding w3-card-4 w3-hide"></div>
46
            </div>
47
        </div>
48
 
49
        <footer class="w3-container w3-center w3-border-top w3-margin">
17 - 50
            <div w3-include-html="php/footer.php"></div>
2 - 51
        </footer>
52
 
53
    </div>
54
 
55
    <script>
56
 
57
// Globals
58
var configGetRecommendations = true;
59
var xml = '';
60
var listItems = [];
61
 
62
// Initialize Configuration Variables
63
function initConfig() {
6 - 64
    var i;
65
    var j;
2 - 66
 
6 - 67
    eBayAuthToken = readCookie();
68
    if (eBayAuthToken.length > 0) {
69
        connected();
70
    }
2 - 71
 
6 - 72
    if (eBayAuthTokenFlag === false) {
73
        var x = document.getElementById("login");
74
        if (x.className.indexOf("w3-show") == -1) {
75
            x.className += " w3-show";
76
        }
77
    }
2 - 78
 
6 - 79
    var xhttp = new XMLHttpRequest();
80
    xhttp.onreadystatechange = function() {
81
        if (this.readyState == 4 && this.status == 200) {
82
            //window.alert(this.responseText);
2 - 83
 
6 - 84
            var parser = new DOMParser();
85
            var htmlDoc = parser.parseFromString(this.responseText, "text/html");
86
            var x = htmlDoc.getElementsByTagName("a");
2 - 87
 
6 - 88
            listItems = [];
2 - 89
 
6 - 90
            for (i = 0, j = 0; i < x.length; i++) {
91
                if (htmlDoc.getElementsByTagName("a")[i].innerHTML.endsWith(".xml")) {
92
                    var n = htmlDoc.getElementsByTagName("a")[i].innerHTML.lastIndexOf(".xml");
93
                    listItems[j] = htmlDoc.getElementsByTagName("a")[i].innerHTML.substr(0, n);
94
                    j++;
95
                }
96
            }
2 - 97
 
6 - 98
            document.getElementById('numberOfListings').innerHTML = j + ' Listing(s) Ready for eBay Upload';
99
        }
100
    };
2 - 101
 
6 - 102
    xhttp.open("GET", configListingUrl + '?t=' + Math.random(), true);
103
    xhttp.send();
2 - 104
}
105
 
106
function requireNewLogin() {
6 - 107
    // dummy
2 - 108
}
109
 
110
function uploadListings() {
6 - 111
    var i = 0;
2 - 112
 
6 - 113
    document.getElementById("logging").innerHTML = '';
114
    document.getElementById("results").innerHTML = '';
2 - 115
 
6 - 116
    initProgressBar('Uploading Listings');
2 - 117
 
6 - 118
    function for1() {
119
        updateProgressBar(listItems.length, i);
120
        uploadListing(listItems[i]);
121
        for2();
122
    }
2 - 123
 
6 - 124
    function for2() {
125
        if (i == listItems.length) {
126
            endProgressBar();
127
            return false;
128
        }
2 - 129
 
6 - 130
        setTimeout(function() {
131
            i++;
132
            document.getElementById("logging").innerHTML = 'Uploading No. ' + i + '/' + listItems.length;
133
            for1();
134
        }, 500);
135
    }
2 - 136
 
6 - 137
    for1();
2 - 138
}
139
 
140
function uploadListing(name) {
6 - 141
    var xhttp;
2 - 142
 
6 - 143
    xhttp = new XMLHttpRequest();
2 - 144
 
6 - 145
    xhttp.onreadystatechange = function() {
146
        if (this.readyState == 4 && this.status == 200) {
147
            //			verifyListing(name, xhttp.responseText);
148
            submitListing(name, xhttp.responseText);
149
        }
150
    };
2 - 151
 
6 - 152
    xhttp.open("GET", configListingUrl + name + '.xml', true);
153
    xhttp.send();
2 - 154
}
155
 
156
function verifyListing(name, itemXML) {
6 - 157
    var i;
158
    var authErrorFlag = false;
2 - 159
 
6 - 160
    if (eBayAuthTokenFlag === false) {
161
        return;
162
    }
2 - 163
 
6 - 164
    var xw = new XMLWriter('UTF-8', '1.0');
165
    var xhr = new XMLHttpRequest();
2 - 166
 
6 - 167
    createAddXML(xw, xhr, 'VerifyAddItemRequest', 'VerifyAddItem', itemXML);
2 - 168
 
6 - 169
    xml = xw.flush();
170
    xw.close();
2 - 171
 
6 - 172
    xhr.onload = function() {
12 - 173
        var jsonObj = XMLparse(xhr.responseXML, false);
174
        var obj = jsonObj.VerifyAddItemResponse;
6 - 175
        var returnCode = obj.Ack;
2 - 176
 
6 - 177
        var x = document.getElementById("results");
178
        if (x.className.indexOf("w3-show") == -1) {
179
            x.className += " w3-show";
180
        }
2 - 181
 
6 - 182
        if (returnCode == 'Success' || (returnCode == 'Warning' && obj.Errors.ErrorCode == '21917108')) {
183
            x.innerHTML += '<p><strong>' + returnCode + ' (' + name + ')</strong></p>';
2 - 184
 
6 - 185
            if (returnCode == 'Warning') {
186
                x.innerHTML += "<p>" + obj.Errors.SeverityCode + " (" + obj.Errors.ErrorCode + "): " + escapeHtml(obj.Errors.LongMessage) + "</p>";
187
            }
12 - 188
            var fees = getJsonArray(obj.Fees.Fee);
6 - 189
            x.innerHTML += "<p>";
190
            for (i = 0; i < fees.length; i++) {
191
                if (fees[i].Fee.text !== "0.0") {
192
                    x.innerHTML += fees[i].Name + ": $" + Number(fees[i].Fee.text).toFixed(2) + "<br/>";
193
                }
194
            }
195
            x.innerHTML += "</p>";
2 - 196
 
6 - 197
            if (obj.DiscountReason) {
198
                x.innerHTML += "<p>Discount Reason: " + obj.DiscountReason + "</p>";
199
            }
2 - 200
 
6 - 201
            var recommendations = getJsonArray(obj.ListingRecommendations);
202
            for (i = 0; i < recommendations.length; i++) {
203
                x.innerHTML += decode(recommendations[i]);
204
            }
205
        } else {
206
            x.innerHTML += '<p class="w3-red"><strong>' + returnCode + ' (' + name + ')</strong></p>';
2 - 207
 
6 - 208
            var errors = getJsonArray(obj.Errors);
209
            x.innerHTML += "<p>";
210
            for (i = 0; i < errors.length; i++) {
211
                x.innerHTML += errors[i].SeverityCode + " (" + errors[i].ErrorCode + "): " + escapeHtml(errors[i].LongMessage) + "<br/>";
212
                if (errors[i].LongMessage.includes('Auth')) {
213
                    authErrorFlag = true;
214
                }
215
            }
2 - 216
 
6 - 217
            x.innerHTML += "</p>";
2 - 218
 
6 - 219
            if (obj.DuplicateInvocationDetails) {
220
                x.innerHTML += '<p>Duplicate Invocation Id ' + obj.DuplicateInvocationDetails.DuplicateInvocationID + ' Tracking Id' + obj.DuplicateInvocationDetails.InvocationTrackingID + ' Status ' + obj.DuplicateInvocationDetails.Status + '</p>';
221
            }
2 - 222
 
6 - 223
            if (authErrorFlag === true) {
224
                eBayAuthTokenFlag = false;
225
                x = document.getElementById("login");
226
                if (x.className.indexOf("w3-show") == -1) {
227
                    x.className += " w3-show";
228
                }
229
            }
230
        }
2 - 231
 
6 - 232
        if (obj.Message) {
233
            x.innerHTML += obj.Message;
234
        }
235
    };
2 - 236
 
6 - 237
    xhr.send(xml);
2 - 238
}
239
 
240
function decode(recommendation) {
6 - 241
    var str = "<p>";
242
    var i;
2 - 243
 
6 - 244
    str += recommendation.Code + " (" + recommendation.Type + "/" + recommendation.Group + ") for '" + recommendation.FieldName;
245
    if (recommendation.Value) {
246
        str += "': " + recommendation.Value;
247
    }
2 - 248
 
6 - 249
    if (recommendation.Message) {
250
        str += "<br/>" + recommendation.Message;
251
    }
2 - 252
 
6 - 253
    var metadata = recommendation.Metadata;
254
    if (metadata) {
255
        if (metadata.length > 0) {
256
            for (i = 0; i < metadata.length; i++) {
257
                if (metadata[i].Name != "correlationId" &&
258
                    metadata[i].Name != "currency" &&
259
                    metadata[i].Name != "similarItems") {
260
                    str += "<br/>" + metadata[i].Name + " = " + metadata[i].Value;
261
                }
262
            }
263
        } else {
264
            if (metadata.Name != "correlationId" &&
265
                metadata.Name != "currency" &&
266
                metadata.Name != "similarItems") {
267
                str += "<br/>" + metadata.Name + " = " + metadata.Value;
268
            }
269
        }
270
    }
2 - 271
 
6 - 272
    str += "</p>";
2 - 273
 
6 - 274
    return str;
2 - 275
}
276
 
277
function submitListing(name, itemXML) {
6 - 278
    var i;
279
    var authErrorFlag = false;
2 - 280
 
6 - 281
    if (document.getElementById("startButton").className.indexOf("w3-green") == -1) {
282
        return;
283
    }
2 - 284
 
6 - 285
    var xw = new XMLWriter('UTF-8', '1.0');
286
    var xhr = new XMLHttpRequest();
2 - 287
 
6 - 288
    createAddXML(xw, xhr, 'AddItemRequest', 'AddItem', itemXML);
2 - 289
 
6 - 290
    xml = xw.flush();
291
    xw.close();
2 - 292
 
6 - 293
    xhr.onload = function() {
12 - 294
        var jsonObj = XMLparse(xhr.responseXML, false);
295
        var obj = jsonObj.AddItemResponse;
6 - 296
        var returnCode = obj.Ack;
2 - 297
 
6 - 298
        var x = document.getElementById("results");
299
        if (x.className.indexOf("w3-show") == -1) {
300
            x.className += " w3-show";
301
        }
2 - 302
 
6 - 303
        if (returnCode == 'Success' || (returnCode == 'Warning' && obj.Errors.ErrorCode == '21917108')) {
304
            x.innerHTML += '<p><strong>' + returnCode + '</strong>, Item Id <a href="https://www.ebay.com/itm/' + obj.ItemID + '" target="_blank">' + obj.ItemID + '</a> (' + name + ')</p>';
305
            if (returnCode == 'Warning') {
306
                x.innerHTML += "<p>" + obj.Errors.SeverityCode + " (" + obj.Errors.ErrorCode + "): " + escapeHtml(obj.Errors.LongMessage) + "</p>";
307
            }
2 - 308
 
12 - 309
            var fees = getJsonArray(obj.Fees.Fee);
6 - 310
            x.innerHTML += "<p>";
311
            for (i = 0; i < fees.length; i++) {
312
                if (fees[i].Fee.text !== "0.0") {
313
                    x.innerHTML += fees[i].Name + ": $" + Number(fees[i].Fee.text).toFixed(2) + "<br/>";
314
                }
315
            }
316
            x.innerHTML += "</p>";
2 - 317
 
6 - 318
            if (obj.DiscountReason) {
319
                x.innerHTML += "<p>Discount Reason: " + obj.DiscountReason + "</p>";
320
            }
321
        } else {
322
            x.innerHTML += '<p class="w3-red"><strong>' + returnCode + ' (' + name + ')</strong></p>';
2 - 323
 
6 - 324
            var errors = getJsonArray(obj.Errors);
325
            x.innerHTML += "<p>";
326
            for (i = 0; i < errors.length; i++) {
327
                x.innerHTML += errors[i].SeverityCode + " (" + errors[i].ErrorCode + "): " + escapeHtml(errors[i].LongMessage) + "<br/>";
328
                if (errors[i].LongMessage.includes('Auth')) {
329
                    authErrorFlag = true;
330
                }
331
            }
332
            x.innerHTML += "</p>";
2 - 333
 
6 - 334
            if (obj.DuplicateInvocationDetails) {
335
                x.innerHTML += '<p>Duplicate Invocation Id ' + obj.DuplicateInvocationDetails.DuplicateInvocationID + ' Tracking Id' + obj.DuplicateInvocationDetails.InvocationTrackingID + ' Status ' + obj.DuplicateInvocationDetails.Status + '</p>';
336
            }
2 - 337
 
6 - 338
            if (authErrorFlag === true) {
339
                eBayAuthTokenFlag = false;
340
                x = document.getElementById("login");
341
                if (x.className.indexOf("w3-show") == -1) {
342
                    x.className += " w3-show";
343
                }
344
            }
345
        }
346
    };
2 - 347
 
6 - 348
    xhr.send(xml);
2 - 349
}
350
 
351
function createAddXML(xw, xhr, xmlrequest, callname, itemXML) {
6 - 352
    xw.writeStartDocument();
353
    xw.writeStartElement(xmlrequest);
354
    xw.writeAttributeString('xmlns', 'urn:ebay:apis:eBLBaseComponents');
2 - 355
 
6 - 356
    xw.writeStartElement('RequesterCredentials');
357
    xw.writeElementString('eBayAuthToken', eBayAuthToken);
358
    xw.writeEndElement(); /* RequesterCredentials */
2 - 359
 
6 - 360
    xw.writeXML(itemXML);
2 - 361
 
6 - 362
    xw.writeElementString('ErrorLanguage', 'en_US');
363
    xw.writeElementString('Version', configeBayTradingVersion);
364
    xw.writeElementString('WarningLevel', configWarningLevel);
2 - 365
 
6 - 366
    xw.writeEndElement(); /* xmlrequest */
367
    xw.writeEndDocument();
2 - 368
 
6 - 369
    xhr.open('POST', configProxyUrl, true);
370
    xhr.setRequestHeader('Content-Type', 'text/xml');
371
    xhr.setRequestHeader('X-EBAY-API-APP-NAME', configAppid);
372
    xhr.setRequestHeader('X-EBAY-API-COMPATIBILITY-LEVEL', configeBayTradingVersion);
373
    xhr.setRequestHeader('X-EBAY-API-CALL-NAME', callname);
374
    xhr.setRequestHeader('X-EBAY-API-SITEID', '0');
375
    xhr.setRequestHeader('X-EBAY-API-DEV-NAME', '');
376
    xhr.setRequestHeader('X-EBAY-API-CERT-NAME', '');
377
    xhr.setRequestHeader('X-Proxy-URL', configServiceEndpoint);
2 - 378
}
379
 
380
function clearStatusWindows() {
6 - 381
    var x = document.getElementById("results");
382
    x.innerHTML = "";
383
    x.className = x.className.replace(" w3-show", "");
2 - 384
}
385
 
386
function connected() {
6 - 387
    var x;
2 - 388
 
6 - 389
    eBayAuthTokenFlag = true;
390
    document.getElementById("connected").innerHTML += " (Connected)";
2 - 391
 
6 - 392
    x = document.getElementById("startButton");
393
    x.className = x.className.replace(" w3-red", " w3-green");
2 - 394
 
6 - 395
    x = document.getElementById("login");
396
    x.className = x.className.replace(" w3-show", "");
2 - 397
}
398
 
399
    </script>
17 - 400
    <script>includeHTML();</script>
2 - 401
 
402
</body>
403
</html>