Skip to content

Commit

Permalink
deploy: 4c74b2b
Browse files Browse the repository at this point in the history
  • Loading branch information
mtrezza committed Mar 19, 2024
1 parent 79cf718 commit 00553fa
Show file tree
Hide file tree
Showing 68 changed files with 9,901 additions and 1 deletion.
3 changes: 3 additions & 0 deletions api/7.0.0/AccountLockoutOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/AuthAdapter.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/CustomPagesOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/DatabaseOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/FileUploadOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/IdempotencyOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/LiveQueryOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/LiveQueryServerOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/LogLevels.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/PagesCustomUrlsOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/PagesOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/PagesRoute.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.AfterFindRequest.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.BeforeFindRequest.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.ConnectTriggerRequest.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.FileTriggerRequest.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.FunctionRequest.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.JobRequest.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.LiveQueryEventTrigger.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.TriggerRequest.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.Cloud.ValidatorObject.html

Large diffs are not rendered by default.

100 changes: 100 additions & 0 deletions api/7.0.0/Parse.Cloud.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/Parse.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/ParseAuthResponse.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/ParseServer.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/ParseServerOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/PasswordPolicyOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/PubSubAdapter.Publisher.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/PubSubAdapter.Subscriber.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/RateLimitOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/SchemaOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/SecurityOptions.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/WSAdapter.html

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions api/7.0.0/data/search.json

Large diffs are not rendered by default.

Binary file added api/7.0.0/fonts/Inconsolata-Regular.ttf
Binary file not shown.
Binary file added api/7.0.0/fonts/OpenSans-Regular.ttf
Binary file not shown.
Binary file added api/7.0.0/fonts/WorkSans-Bold.ttf
Binary file not shown.
3 changes: 3 additions & 0 deletions api/7.0.0/global.html

Large diffs are not rendered by default.

431 changes: 431 additions & 0 deletions api/7.0.0/index.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/module-AdapterLoader.html

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/module-Adapters.CacheAdapter.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/module-Adapters.FilesAdapter.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/module-Adapters.PubSubAdapter.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/module-Adapters.PushAdapter.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/module-Adapters.WSSAdapter.html

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions api/7.0.0/module-Adapters.html

Large diffs are not rendered by default.

655 changes: 655 additions & 0 deletions api/7.0.0/scripts/core.js

Large diffs are not rendered by default.

23 changes: 23 additions & 0 deletions api/7.0.0/scripts/core.min.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

90 changes: 90 additions & 0 deletions api/7.0.0/scripts/resize.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
/* global document */
// This file is @deprecated

var NAVBAR_OPTIONS = {};

(function() {
var NAVBAR_RESIZE_LOCAL_STORAGE_KEY = 'NAVBAR_RESIZE_LOCAL_STORAGE_KEY';

var navbar = document.querySelector('#navbar');
var footer = document.querySelector('#footer');
var mainSection = document.querySelector('#main');
var localStorageResizeObject = JSON.parse(
// eslint-disable-next-line no-undef
localStorage.getItem(NAVBAR_RESIZE_LOCAL_STORAGE_KEY)
);

/**
* Check whether we have any resize value in local storage or not.
* If we have resize value then resize the navbar.
**/
if (localStorageResizeObject) {
navbar.style.width = localStorageResizeObject.width;
mainSection.style.marginLeft = localStorageResizeObject.width;
footer.style.marginLeft = localStorageResizeObject.width;
}

var navbarSlider = document.querySelector('#navbar-resize');

function resizeNavbar(event) {
var pageX = event.pageX,
pageXPlusPx = event.pageX + 'px',
min = Number.parseInt(NAVBAR_OPTIONS.min, 10) || 300,
max = Number.parseInt(NAVBAR_OPTIONS.max, 10) || 600;

/**
* Just to add some checks. If min is smaller than 10 then
* user may accidentally end up reducing the size of navbar
* less than 10. In that case user will not able to resize navbar
* because navbar slider will be hidden.
*/
if (min < 10) {
min = 10;
}

/**
* Only resize if pageX in range between min and max
* allowed value.
*/
if (min < pageX && pageX < max) {
navbar.style.width = pageXPlusPx;
mainSection.style.marginLeft = pageXPlusPx;
footer.style.marginLeft = pageXPlusPx;
}
}

function setupEventListeners() {
// eslint-disable-next-line no-undef
window.addEventListener('mousemove', resizeNavbar);
// eslint-disable-next-line no-undef
window.addEventListener('touchmove', resizeNavbar);
}

function afterRemovingEventListeners() {
// eslint-disable-next-line no-undef
localStorage.setItem(
NAVBAR_RESIZE_LOCAL_STORAGE_KEY,
JSON.stringify({
width: navbar.style.width
})
);
}

function removeEventListeners() {
// eslint-disable-next-line no-undef
window.removeEventListener('mousemove', resizeNavbar);
// eslint-disable-next-line no-undef
window.removeEventListener('touchend', resizeNavbar);
afterRemovingEventListeners();
}

navbarSlider.addEventListener('mousedown', setupEventListeners);
navbarSlider.addEventListener('touchstart', setupEventListeners);
// eslint-disable-next-line no-undef
window.addEventListener('mouseup', removeEventListeners);
})();

// eslint-disable-next-line no-unused-vars
function setupResizeOptions(options) {
NAVBAR_OPTIONS = options;
}
265 changes: 265 additions & 0 deletions api/7.0.0/scripts/search.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,265 @@
/* global document */

const searchId = 'LiBfqbJVcV';
const searchHash = '#' + searchId;
const searchContainer = document.querySelector('#PkfLWpAbet');
const searchWrapper = document.querySelector('#iCxFxjkHbP');
const searchCloseButton = document.querySelector('#VjLlGakifb');
const searchInput = document.querySelector('#vpcKVYIppa');
const resultBox = document.querySelector('#fWwVHRuDuN');

function showResultText(text) {
resultBox.innerHTML = `<span class="search-result-c-text">${text}</span>`;
}

function hideSearch() {
// eslint-disable-next-line no-undef
if (window.location.hash === searchHash) {
// eslint-disable-next-line no-undef
history.go(-1);
}

// eslint-disable-next-line no-undef
window.onhashchange = null;

if (searchContainer) {
searchContainer.style.display = 'none';
}
}

function listenCloseKey(event) {
if (event.key === 'Escape') {
hideSearch();
// eslint-disable-next-line no-undef
window.removeEventListener('keyup', listenCloseKey);
}
}

function showSearch() {
try {
// Closing mobile menu before opening
// search box.
// It is defined in core.js
// eslint-disable-next-line no-undef
hideMobileMenu();
} catch (error) {
console.error(error);
}

// eslint-disable-next-line no-undef
window.onhashchange = hideSearch;

// eslint-disable-next-line no-undef
if (window.location.hash !== searchHash) {
// eslint-disable-next-line no-undef
history.pushState(null, null, searchHash);
}

if (searchContainer) {
searchContainer.style.display = 'flex';
// eslint-disable-next-line no-undef
window.addEventListener('keyup', listenCloseKey);
}

if (searchInput) {
searchInput.focus();
}
}

async function fetchAllData() {
// eslint-disable-next-line no-undef
const { hostname, protocol, port } = location;

// eslint-disable-next-line no-undef
const base = protocol + '//' + hostname + (port !== '' ? ':' + port : '') + baseURL;
// eslint-disable-next-line no-undef
const url = new URL('data/search.json', base);
const result = await fetch(url);
const { list } = await result.json();

return list;
}

// eslint-disable-next-line no-unused-vars
function onClickSearchItem(event) {
const target = event.currentTarget;

if (target) {
const href = target.getAttribute('href') || '';
let elementId = href.split('#')[1] || '';
let element = document.getElementById(elementId);

if (!element) {
elementId = decodeURI(elementId);
element = document.getElementById(elementId);
}

if (element) {
setTimeout(function() {
// eslint-disable-next-line no-undef
bringElementIntoView(element); // defined in core.js
}, 100);
}
}
}

function buildSearchResult(result) {
let output = '';
const removeHTMLTagsRegExp = /(<([^>]+)>)/ig;

for (const res of result) {
const { title = '', description = '' } = res.item;

const _link = res.item.link.replace('<a href="', '').replace(/">.*/, '');
const _title = title.replace(removeHTMLTagsRegExp, "");
const _description = description.replace(removeHTMLTagsRegExp, "");

output += `
<a onclick="onClickSearchItem(event)" href="${_link}" class="search-result-item">
<div class="search-result-item-title">${_title}</div>
<div class="search-result-item-p">${_description || 'No description available.'}</div>
</a>
`;
}

return output;
}

function getSearchResult(list, keys, searchKey) {
const defaultOptions = {
shouldSort: true,
threshold: 0.4,
location: 0,
distance: 100,
maxPatternLength: 32,
minMatchCharLength: 1,
keys: keys
};

const options = { ...defaultOptions };

// eslint-disable-next-line no-undef
const searchIndex = Fuse.createIndex(options.keys, list);

// eslint-disable-next-line no-undef
const fuse = new Fuse(list, options, searchIndex);

const result = fuse.search(searchKey);

if (result.length > 20) {
return result.slice(0, 20);
}

return result;
}

function debounce(func, wait, immediate) {
let timeout;

return function() {
const args = arguments;

clearTimeout(timeout);
timeout = setTimeout(() => {
timeout = null;
if (!immediate) {
// eslint-disable-next-line consistent-this, no-invalid-this
func.apply(this, args);
}
}, wait);

if (immediate && !timeout) {
// eslint-disable-next-line consistent-this, no-invalid-this
func.apply(this, args);
}
};
}

let searchData;

async function search(event) {
const value = event.target.value;
const keys = ['title', 'description'];

if (!resultBox) {
console.error('Search result container not found');

return;
}

if (!value) {
showResultText('Type anything to view search result');

return;
}

if (!searchData) {
showResultText('Loading...');

try {
// eslint-disable-next-line require-atomic-updates
searchData = await fetchAllData();
} catch (e) {
console.log(e);
showResultText('Failed to load result.');

return;
}
}

const result = getSearchResult(searchData, keys, value);

if (!result.length) {
showResultText('No result found! Try some different combination.');

return;
}

// eslint-disable-next-line require-atomic-updates
resultBox.innerHTML = buildSearchResult(result);
}

function onDomContentLoaded() {
const searchButton = document.querySelectorAll('.search-button');
const debouncedSearch = debounce(search, 300);

if (searchCloseButton) {
searchCloseButton.addEventListener('click', hideSearch);
}

if (searchButton) {
searchButton.forEach(function(item) {
item.addEventListener('click', showSearch);
});
}

if (searchContainer) {
searchContainer.addEventListener('click', hideSearch);
}

if (searchWrapper) {
searchWrapper.addEventListener('click', function(event) {
event.stopPropagation();
});
}

if (searchInput) {
searchInput.addEventListener('keyup', debouncedSearch);
}

// eslint-disable-next-line no-undef
if (window.location.hash === searchHash) {
showSearch();
}
}

// eslint-disable-next-line no-undef
window.addEventListener('DOMContentLoaded', onDomContentLoaded);

// eslint-disable-next-line no-undef
window.addEventListener('hashchange', function() {
// eslint-disable-next-line no-undef
if (window.location.hash === searchHash) {
showSearch();
}
});
Loading

0 comments on commit 00553fa

Please sign in to comment.