multiple libraries, add request and cookie
This commit is contained in:
parent
ad8fe8fa85
commit
1d636cdc79
@ -24,6 +24,7 @@
|
||||
</div>
|
||||
<div id="buttons" class="app-module">
|
||||
<button title="Edit Contact">Edit</button>
|
||||
<button id="button-fetch" title="Fetch">Fetch</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { createIcon, resolveIcon } from "./ui/icon"
|
||||
import { createCheckbox, resolveCheckbox } from "./ui/checkbox"
|
||||
import { setTooltip, resolveTooltip } from "./ui/tooltip"
|
||||
import { createIcon, resolveIcon } from "./ui/icon";
|
||||
import { createCheckbox, resolveCheckbox } from "./ui/checkbox";
|
||||
import { setTooltip, resolveTooltip } from "./ui/tooltip";
|
||||
|
||||
export {
|
||||
createIcon,
|
||||
|
10
lib/utility.js
Normal file
10
lib/utility.js
Normal file
@ -0,0 +1,10 @@
|
||||
import { getCookie, setCookie, deleteCookie } from "./utility/cookie";
|
||||
import { get, post } from "./utility/request";
|
||||
|
||||
export {
|
||||
getCookie,
|
||||
setCookie,
|
||||
deleteCookie,
|
||||
get,
|
||||
post
|
||||
}
|
3
lib/utility/cookie.d.ts
vendored
Normal file
3
lib/utility/cookie.d.ts
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
export function getCookie(name: string): string
|
||||
export function setCookie(name: string, value: string, expireDays?: Number): void
|
||||
export function deleteCookie(name: string): void
|
34
lib/utility/cookie.js
Normal file
34
lib/utility/cookie.js
Normal file
@ -0,0 +1,34 @@
|
||||
function setCookie(name, value, expireDays) {
|
||||
let extra = `; domain=${location.host}; path=/`;
|
||||
if (expireDays != null) {
|
||||
const d = new Date();
|
||||
d.setTime(d.getTime() + (expireDays * 24 * 60 * 60 * 1000));
|
||||
extra += `; expires=${d.toGMTString()}`;
|
||||
}
|
||||
if (/^(https|wss):$/.test(location.protocol)) {
|
||||
extra += '; secure';
|
||||
}
|
||||
document.cookie = `${name}=${encodeURIComponent(value)}${extra}`;
|
||||
}
|
||||
|
||||
function getCookie(name) {
|
||||
name += '=';
|
||||
const cookies = document.cookie.split(';');
|
||||
for (let cookie of cookies) {
|
||||
cookie = cookie.trim();
|
||||
if (cookie.indexOf(name) === 0) {
|
||||
return decodeURIComponent(cookie.substring(name.length));
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
function deleteCookie(name) {
|
||||
setCookie(name, '', -1);
|
||||
}
|
||||
|
||||
export {
|
||||
getCookie,
|
||||
setCookie,
|
||||
deleteCookie
|
||||
}
|
9
lib/utility/request.d.ts
vendored
Normal file
9
lib/utility/request.d.ts
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
interface RequestOptions {
|
||||
method?: string;
|
||||
contentType?: string;
|
||||
customerHeaders?: { [key: string]: string };
|
||||
signal?: AbortSignal | null;
|
||||
}
|
||||
|
||||
export function get(url: string, options?: RequestOptions): Promise<Response>
|
||||
export function post(url: string, data?: BodyInit | null, options?: RequestOptions): Promise<Response>
|
38
lib/utility/request.js
Normal file
38
lib/utility/request.js
Normal file
@ -0,0 +1,38 @@
|
||||
function combineUrl(url) {
|
||||
if (typeof consts === 'undefined') {
|
||||
return url;
|
||||
}
|
||||
return (consts.path || '') + url;
|
||||
}
|
||||
|
||||
function get(url, options) {
|
||||
options ??= {};
|
||||
return fetch(combineUrl(url), {
|
||||
method: options.method || 'GET',
|
||||
headers: {
|
||||
...options.customerHeaders,
|
||||
'Content-Type': options.contentType || 'application/json'
|
||||
},
|
||||
signal: options.signal,
|
||||
cache: 'default'
|
||||
});
|
||||
}
|
||||
|
||||
function post(url, data, options) {
|
||||
options ??= {};
|
||||
return fetch(combineUrl(url), {
|
||||
method: options.method || 'POST',
|
||||
headers: {
|
||||
...options.customerHeaders,
|
||||
'Content-Type': options.contentType || 'application/json'
|
||||
},
|
||||
body: data,
|
||||
signal: options.signal,
|
||||
cache: 'no-cache'
|
||||
});
|
||||
}
|
||||
|
||||
export {
|
||||
get,
|
||||
post
|
||||
}
|
16
main.js
16
main.js
@ -1,9 +1,10 @@
|
||||
import './css/ui.min.css'
|
||||
import './style.css'
|
||||
import javascriptLogo from './javascript.svg'
|
||||
// import javascriptLogo from './javascript.svg'
|
||||
import { resolveCheckbox, resolveIcon, resolveTooltip } from './lib/ui'
|
||||
import { get, post } from './lib/utility'
|
||||
|
||||
document.querySelector('#js-logo').src = javascriptLogo
|
||||
// document.querySelector('#js-logo').src = javascriptLogo
|
||||
|
||||
window.consts = {
|
||||
path: '/',
|
||||
@ -18,4 +19,13 @@ resolveIcon(document.querySelector('#create-icon'))
|
||||
// }))
|
||||
resolveCheckbox(document.querySelector('#create-checkbox'))
|
||||
|
||||
resolveTooltip(document.querySelector('#buttons'))
|
||||
resolveTooltip(document.querySelector('#buttons'))
|
||||
|
||||
document.querySelector('#button-fetch').addEventListener('click', () => {
|
||||
// get('./javascript.svg')
|
||||
// .then(r => r.blob())
|
||||
// .then(blob => document.querySelector('#js-logo').src = URL.createObjectURL(blob));
|
||||
post('./', JSON.stringify({ a: 1, b: 'test' }))
|
||||
.then(r => console.log(r))
|
||||
.catch(e => console.warn(e));
|
||||
});
|
14
package.json
14
package.json
@ -6,17 +6,19 @@
|
||||
"files": [
|
||||
"dist"
|
||||
],
|
||||
"main": "./dist/ui-lib.umd.cjs",
|
||||
"module": "./dist/ui-lib.js",
|
||||
"exports": {
|
||||
"./lib": {
|
||||
"import": "./dist/ui-lib.js",
|
||||
"require": "./dist/ui-lib.umd.cjs"
|
||||
"ui": {
|
||||
"import": "./dist/ui.es.js",
|
||||
"require": "./dist/ui.min.js"
|
||||
},
|
||||
"utility": {
|
||||
"import": "./dist/utility.es.js",
|
||||
"require": "./dist/utility.min.js"
|
||||
}
|
||||
},
|
||||
"scripts": {
|
||||
"dev": "vite",
|
||||
"build": "vite build"
|
||||
"build": "node ./vite.build.js"
|
||||
},
|
||||
"devDependencies": {
|
||||
"vite": "^4.0.4"
|
||||
|
24
vite.build.js
Normal file
24
vite.build.js
Normal file
@ -0,0 +1,24 @@
|
||||
import { build } from "vite";
|
||||
|
||||
const libraries = [
|
||||
{
|
||||
entry: './lib/ui.js',
|
||||
name: 'lib-ui'
|
||||
},
|
||||
{
|
||||
entry: './lib/utility.js',
|
||||
name: 'lib-utility'
|
||||
}
|
||||
]
|
||||
|
||||
libraries.forEach(async (lib) => {
|
||||
await build({
|
||||
build: {
|
||||
lib: {
|
||||
...lib,
|
||||
formats: ['umd'],
|
||||
fileName: (_format, name) => `${name}.min.js`
|
||||
}
|
||||
}
|
||||
})
|
||||
})
|
@ -1,11 +0,0 @@
|
||||
import { defineConfig } from "vite";
|
||||
|
||||
export default defineConfig({
|
||||
build: {
|
||||
lib: {
|
||||
entry: './lib/main.js',
|
||||
name: 'uiLib',
|
||||
fileName: 'ui-lib'
|
||||
}
|
||||
}
|
||||
})
|
Loading…
x
Reference in New Issue
Block a user