Compare commits

..

4 Commits

Author SHA1 Message Date
Leifer Mendez
5735b49e25 Merge pull request #155 from leifermendez/feat/releases
feat(release): added
2022-12-08 22:23:03 +01:00
Leifer Mendez
cb33c0df68 Merge pull request #154 from leifermendez/feat/releases
feat(relases): added
2022-12-08 22:19:25 +01:00
Leifer Mendez
5d7c297f2f Merge pull request #150 from leifermendez/fix/ci-yarn
ci(action): update
2022-12-08 20:17:46 +01:00
Leifer Mendez
bb3f21b056 Merge pull request #149 from leifermendez/fix/ci-yarn
fix(ci): update yarn
2022-12-08 20:13:02 +01:00
45 changed files with 592 additions and 793 deletions

View File

@@ -1 +0,0 @@
packages/docs/*

View File

@@ -10,9 +10,5 @@ module.exports = {
parserOptions: { parserOptions: {
ecmaVersion: 'latest', ecmaVersion: 'latest',
}, },
rules: { rules: {},
'no-unsafe-negation': 'off',
'no-prototype-builtins': 'off',
'no-useless-escape': 'off',
},
} }

View File

@@ -1,105 +1,27 @@
name: BotWhatsapp CI name: Bot CI Test
on: on:
push: push:
branches: branches: [dev]
- main
pull_request: pull_request:
branches: branches: [main]
- main
- dev
jobs: jobs:
############ BUILD PACKAGE ############ build:
build-package:
name: Build Package
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs:
- test-unit
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Setup Node strategy:
matrix:
node-version: [16.x]
steps:
- uses: actions/checkout@v3
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3 uses: actions/setup-node@v3
with: with:
node-version: 16.x node-version: ${{ matrix.node-version }}
cache: 'yarn'
registry-url: https://registry.npmjs.org/
- run: corepack enable - run: corepack enable
- name: Install NPM Dependencies - name: Install NPM Dependencies
run: yarn install --immutable --network-timeout 300000 run: yarn install --immutable --network-timeout 300000
- name: Test
- name: Build Package
run: yarn build
- name: Build Eslint rules
run: yarn lint:fix
############ RELEASE ############
release:
name: Release
runs-on: ubuntu-latest
needs:
- build-package
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 16.x
cache: 'yarn'
registry-url: https://registry.npmjs.org/
- run: corepack enable
- name: Install NPM Dependencies
run: yarn install --immutable --network-timeout 300000
- name: Build Package
run: yarn build
- name: Release @bot-whatsapp/bot
run: yarn node ./scripts/release.js --name=bot --version= --token="${{ secrets.NPM_TOKEN }}"
- name: Release @bot-whatsapp/cli
run: yarn node ./scripts/release.js --name=cli --version= --token="${{ secrets.NPM_TOKEN }}"
- name: Release @bot-whatsapp/create-bot-whatsapp
run: yarn node ./scripts/release.js --name=create-bot-whatsapp --version= --token="${{ secrets.NPM_TOKEN }}"
- name: Release @bot-whatsapp/create-bot-whatsapp
run: yarn node ./scripts/release.js --name=create-bot-whatsapp --version= --token="${{ secrets.NPM_TOKEN }}"
- name: Release @bot-whatsapp/database
run: yarn node ./scripts/release.js --name=database --version= --token="${{ secrets.NPM_TOKEN }}"
- name: Release @bot-whatsapp/provider
run: yarn node ./scripts/release.js --name=provider --version= --token="${{ secrets.NPM_TOKEN }}"
############ UNIT TEST ############
test-unit:
name: Unit Tests
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 16.x
cache: 'yarn'
registry-url: https://registry.npmjs.org/
- run: corepack enable
- name: Install NPM Dependencies
run: yarn install --immutable --network-timeout 300000
- name: Unit Tests
run: yarn test run: yarn test

View File

@@ -1,10 +1,11 @@
name: Add contributors name: Add contributors
on: on:
schedule:
- cron: '20 20 * * *'
push:
branches: [dev]
pull_request: pull_request:
branches: branches: [main, dev]
- dev
- main
types: [closed]
jobs: jobs:
contrib-readme-job: contrib-readme-job:

26
.github/workflows/relases.yml vendored Normal file
View File

@@ -0,0 +1,26 @@
name: Bot Relases
on:
release:
types: [released, published]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [16.x]
steps:
- uses: actions/checkout@v3
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node-version }}
- run: corepack enable
- name: Install NPM Dependencies
run: yarn install --immutable --network-timeout 300000
- name: Test
run: yarn test
- name: Build
run: yarn build

2
.gitignore vendored
View File

@@ -20,7 +20,6 @@ coverage/
log log
log/* log/*
*.log *.log
*.tgz
lib lib
tmp/ tmp/
.yarn/* .yarn/*
@@ -31,4 +30,3 @@ example-app*/
qr.svg qr.svg
package-lock.json package-lock.json
yarn-error.log yarn-error.log
.npmrc

View File

@@ -11,13 +11,12 @@
"bot:rollup": "rollup --config ./packages/bot/rollup-bot.config.js", "bot:rollup": "rollup --config ./packages/bot/rollup-bot.config.js",
"provider:rollup": "rollup --config ./packages/provider/rollup-provider.config.js ", "provider:rollup": "rollup --config ./packages/provider/rollup-provider.config.js ",
"database:rollup": "rollup --config ./packages/database/rollup-database.config.js", "database:rollup": "rollup --config ./packages/database/rollup-database.config.js",
"create-bot-whatsapp:rollup": "rollup --config ./packages/create-bot-whatsapp/rollup-create.config.js",
"format:check": "prettier --check ./packages", "format:check": "prettier --check ./packages",
"format:write": "prettier --write ./packages", "format:write": "prettier --write ./packages",
"fmt.staged": "pretty-quick --staged", "fmt.staged": "pretty-quick --staged",
"lint:check": "eslint ./packages", "lint:check": "eslint ./packages",
"lint:fix": "eslint --fix ./packages", "lint:fix": "eslint --fix ./packages",
"build": "yarn run cli:rollup && yarn run bot:rollup && yarn run provider:rollup && yarn run database:rollup && yarn run create-bot-whatsapp:rollup", "build": "yarn run cli:rollup && yarn run bot:rollup && yarn run provider:rollup && yarn run database:rollup",
"copy.lib": "node ./scripts/move.js", "copy.lib": "node ./scripts/move.js",
"test.unit": "node ./node_modules/uvu/bin.js packages test", "test.unit": "node ./node_modules/uvu/bin.js packages test",
"test.coverage": "node ./node_modules/c8/bin/c8.js npm run test.unit", "test.coverage": "node ./node_modules/c8/bin/c8.js npm run test.unit",
@@ -81,7 +80,6 @@
"rollup": "^3.2.3", "rollup": "^3.2.3",
"rollup-plugin-cleanup": "^3.2.1", "rollup-plugin-cleanup": "^3.2.1",
"rollup-plugin-copy": "^3.4.0", "rollup-plugin-copy": "^3.4.0",
"semver": "^7.3.8",
"standard-version": "^9.5.0", "standard-version": "^9.5.0",
"uvu": "^0.5.6" "uvu": "^0.5.6"
}, },

View File

@@ -1,8 +1,9 @@
{ {
"name": "@bot-whatsapp/bot", "name": "@bot-whatsapp/bot",
"version": "0.0.4-alpha.0", "version": "0.0.1",
"description": "", "description": "",
"main": "./lib/bundle.bot.cjs", "main": "./lib/bundle.bot.cjs",
"private": true,
"scripts": { "scripts": {
"bot:rollup": "node ../../node_modules/.bin/rollup index.js --config ./rollup-cli.config.js", "bot:rollup": "node ../../node_modules/.bin/rollup index.js --config ./rollup-cli.config.js",
"format:check": "prettier --check .", "format:check": "prettier --check .",

View File

@@ -19,7 +19,7 @@ class ProviderClass extends EventEmitter {
* *
*/ */
sendMessage = async (userId, message) => { sendMessage = async (userId, message, sendMessage) => {
if (NODE_ENV !== 'production') if (NODE_ENV !== 'production')
console.log('[sendMessage]', { userId, message }) console.log('[sendMessage]', { userId, message })
return message return message

View File

@@ -1,8 +1,9 @@
{ {
"name": "@bot-whatsapp/cli", "name": "@bot-whatsapp/cli",
"version": "0.0.2-alpha.0", "version": "0.0.1",
"description": "", "description": "",
"main": "index.js", "main": "index.js",
"private": true,
"devDependencies": { "devDependencies": {
"cross-env": "^7.0.3", "cross-env": "^7.0.3",
"cross-spawn": "^7.0.3", "cross-spawn": "^7.0.3",

View File

@@ -1,8 +1,9 @@
{ {
"name": "create-bot-whatsapp", "name": "create-bot-whatsapp",
"version": "0.0.9-alpha.0", "version": "0.0.1",
"description": "", "description": "",
"main": "./lib/bin/bundle.create.cjs", "main": "./lib/bin/bundle.create.cjs",
"private": true,
"dependencies": { "dependencies": {
"@bot-whatsapp/cli": "*" "@bot-whatsapp/cli": "*"
}, },

View File

@@ -1,8 +1,9 @@
{ {
"name": "@bot-whatsapp/database", "name": "@bot-whatsapp/database",
"version": "0.0.2-alpha.0", "version": "0.0.1",
"description": "Esto es el conector a mysql, pg, mongo", "description": "Esto es el conector a mysql, pg, mongo",
"main": "./lib/mock/index.cjs", "main": "./lib/mock/index.cjs",
"private": true,
"keywords": [], "keywords": [],
"author": "", "author": "",
"license": "ISC", "license": "ISC",

View File

@@ -1,6 +1,6 @@
import { cloudflarePagesAdaptor } from '@builder.io/qwik-city/adaptors/cloudflare-pages/vite' import { cloudflarePagesAdaptor } from '@builder.io/qwik-city/adaptors/cloudflare-pages/vite';
import { extendConfig } from '@builder.io/qwik-city/vite' import { extendConfig } from '@builder.io/qwik-city/vite';
import baseConfig from '../../vite.config' import baseConfig from '../../vite.config';
export default extendConfig(baseConfig, () => { export default extendConfig(baseConfig, () => {
return { return {
@@ -15,5 +15,5 @@ export default extendConfig(baseConfig, () => {
staticGenerate: true, staticGenerate: true,
}), }),
], ],
} };
}) });

View File

@@ -2,4 +2,4 @@
// Cloudflare Pages Functions // Cloudflare Pages Functions
// https://developers.cloudflare.com/pages/platform/functions/ // https://developers.cloudflare.com/pages/platform/functions/
export { onRequest } from '../server/entry.cloudflare-pages' export { onRequest } from '../server/entry.cloudflare-pages';

View File

@@ -1,16 +1,16 @@
import { component$, useStyles$ } from '@builder.io/qwik' import { component$, useStyles$ } from '@builder.io/qwik';
import { useContent, useLocation, ContentMenu } from '@builder.io/qwik-city' import { useContent, useLocation, ContentMenu } from '@builder.io/qwik-city';
import styles from './breadcrumbs.css?inline' import styles from './breadcrumbs.css?inline';
export const Breadcrumbs = component$(() => { export const Breadcrumbs = component$(() => {
useStyles$(styles) useStyles$(styles);
const { menu } = useContent() const { menu } = useContent();
const loc = useLocation() const loc = useLocation();
const breadcrumbs = createBreadcrumbs(menu, loc.pathname) const breadcrumbs = createBreadcrumbs(menu, loc.pathname);
if (breadcrumbs.length === 0) { if (breadcrumbs.length === 0) {
return null return null;
} }
return ( return (
@@ -19,47 +19,44 @@ export const Breadcrumbs = component$(() => {
<span>{b.href ? <a href={b.href}>{b.text}</a> : b.text}</span> <span>{b.href ? <a href={b.href}>{b.text}</a> : b.text}</span>
))} ))}
</nav> </nav>
) );
}) });
export function createBreadcrumbs( export function createBreadcrumbs(menu: ContentMenu | undefined, pathname: string) {
menu: ContentMenu | undefined,
pathname: string
) {
if (menu?.items) { if (menu?.items) {
for (const indexA of menu.items) { for (const indexA of menu.items) {
const breadcrumbA: ContentBreadcrumb = { const breadcrumbA: ContentBreadcrumb = {
text: indexA.text, text: indexA.text,
} };
if (typeof indexA.href === 'string') { if (typeof indexA.href === 'string') {
breadcrumbA.href = indexA.href breadcrumbA.href = indexA.href;
} }
if (indexA.href === pathname) { if (indexA.href === pathname) {
return [breadcrumbA] return [breadcrumbA];
} }
if (indexA.items) { if (indexA.items) {
for (const indexB of indexA.items) { for (const indexB of indexA.items) {
const breadcrumbB: ContentBreadcrumb = { const breadcrumbB: ContentBreadcrumb = {
text: indexB.text, text: indexB.text,
} };
if (typeof indexB.href === 'string') { if (typeof indexB.href === 'string') {
breadcrumbB.href = indexB.href breadcrumbB.href = indexB.href;
} }
if (indexB.href === pathname) { if (indexB.href === pathname) {
return [breadcrumbA, breadcrumbB] return [breadcrumbA, breadcrumbB];
} }
if (indexB.items) { if (indexB.items) {
for (const indexC of indexB.items) { for (const indexC of indexB.items) {
const breadcrumbC: ContentBreadcrumb = { const breadcrumbC: ContentBreadcrumb = {
text: indexC.text, text: indexC.text,
} };
if (typeof indexC.href === 'string') { if (typeof indexC.href === 'string') {
breadcrumbC.href = indexC.href breadcrumbC.href = indexC.href;
} }
if (indexC.href === pathname) { if (indexC.href === pathname) {
return [breadcrumbA, breadcrumbB, breadcrumbC] return [breadcrumbA, breadcrumbB, breadcrumbC];
} }
} }
} }
@@ -68,10 +65,10 @@ export function createBreadcrumbs(
} }
} }
return [] return [];
} }
interface ContentBreadcrumb { interface ContentBreadcrumb {
text: string text: string;
href?: string href?: string;
} }

View File

@@ -1,8 +1,8 @@
import { component$, useStyles$ } from '@builder.io/qwik' import { component$, useStyles$ } from '@builder.io/qwik';
import styles from './footer.css?inline' import styles from './footer.css?inline';
export default component$(() => { export default component$(() => {
useStyles$(styles) useStyles$(styles);
return ( return (
<footer> <footer>
@@ -27,14 +27,10 @@ export default component$(() => {
</li> </li>
</ul> </ul>
<div> <div>
<a <a href="https://www.builder.io/" target="_blank" class="builder">
href="https://www.builder.io/"
target="_blank"
class="builder"
>
Made with by Builder.io Made with by Builder.io
</a> </a>
</div> </div>
</footer> </footer>
) );
}) });

View File

@@ -1,12 +1,12 @@
import { component$, useStyles$ } from '@builder.io/qwik' import { component$, useStyles$ } from '@builder.io/qwik';
import { useLocation } from '@builder.io/qwik-city' import { useLocation } from '@builder.io/qwik-city';
import { QwikLogo } from '../icons/qwik' import { QwikLogo } from '../icons/qwik';
import styles from './header.css?inline' import styles from './header.css?inline';
export default component$(() => { export default component$(() => {
useStyles$(styles) useStyles$(styles);
const { pathname } = useLocation() const { pathname } = useLocation();
return ( return (
<header> <header>
@@ -14,19 +14,13 @@ export default component$(() => {
<QwikLogo /> <QwikLogo />
</a> </a>
<nav> <nav>
<a <a href="/docs" class={{ active: pathname.startsWith('/docs') }}>
href="/docs"
class={{ active: pathname.startsWith('/docs') }}
>
Docs Docs
</a> </a>
<a <a href="/about-us" class={{ active: pathname.startsWith('/about-us') }}>
href="/about-us"
class={{ active: pathname.startsWith('/about-us') }}
>
About Us About Us
</a> </a>
</nav> </nav>
</header> </header>
) );
}) });

View File

@@ -17,4 +17,4 @@ export const QwikLogo = () => (
d="M33.3 24.69 15.02 4.75l2.6 15.62-4.66 4.51L31.91 43.7l-1.7-15.62 3.1-3.4Z" d="M33.3 24.69 15.02 4.75l2.6 15.62-4.66 4.51L31.91 43.7l-1.7-15.62 3.1-3.4Z"
/> />
</svg> </svg>
) );

View File

@@ -1,12 +1,12 @@
import { component$, useStyles$ } from '@builder.io/qwik' import { component$, useStyles$ } from '@builder.io/qwik';
import { useContent, Link, useLocation } from '@builder.io/qwik-city' import { useContent, Link, useLocation } from '@builder.io/qwik-city';
import styles from './menu.css?inline' import styles from './menu.css?inline';
export default component$(() => { export default component$(() => {
useStyles$(styles) useStyles$(styles);
const { menu } = useContent() const { menu } = useContent();
const loc = useLocation() const loc = useLocation();
return ( return (
<aside class="menu"> <aside class="menu">
@@ -20,8 +20,7 @@ export default component$(() => {
<Link <Link
href={item.href} href={item.href}
class={{ class={{
'is-active': 'is-active': loc.pathname === item.href,
loc.pathname === item.href,
}} }}
> >
{item.text} {item.text}
@@ -33,5 +32,5 @@ export default component$(() => {
)) ))
: null} : null}
</aside> </aside>
) );
}) });

View File

@@ -1,16 +1,15 @@
import { useContent, useLocation } from '@builder.io/qwik-city' import { useContent, useLocation } from '@builder.io/qwik-city';
import { component$, useStyles$ } from '@builder.io/qwik' import { component$, useStyles$ } from '@builder.io/qwik';
import styles from './on-this-page.css?inline' import styles from './on-this-page.css?inline';
export default component$(() => { export default component$(() => {
useStyles$(styles) useStyles$(styles);
const { headings } = useContent() const { headings } = useContent();
const contentHeadings = const contentHeadings = headings?.filter((h) => h.level === 2 || h.level === 3) || [];
headings?.filter((h) => h.level === 2 || h.level === 3) || []
const { pathname } = useLocation() const { pathname } = useLocation();
const editUrl = `#update-your-edit-url-for-${pathname}` const editUrl = `#update-your-edit-url-for-${pathname}`;
return ( return (
<aside class="on-this-page"> <aside class="on-this-page">
@@ -59,5 +58,5 @@ export default component$(() => {
</li> </li>
</ul> </ul>
</aside> </aside>
) );
}) });

View File

@@ -1,22 +1,19 @@
import { component$ } from '@builder.io/qwik' import { component$ } from '@builder.io/qwik';
import { useDocumentHead, useLocation } from '@builder.io/qwik-city' import { useDocumentHead, useLocation } from '@builder.io/qwik-city';
/** /**
* The RouterHead component is placed inside of the document `<head>` element. * The RouterHead component is placed inside of the document `<head>` element.
*/ */
export const RouterHead = component$(() => { export const RouterHead = component$(() => {
const head = useDocumentHead() const head = useDocumentHead();
const loc = useLocation() const loc = useLocation();
return ( return (
<> <>
<title>{head.title}</title> <title>{head.title}</title>
<link rel="canonical" href={loc.href} /> <link rel="canonical" href={loc.href} />
<meta <meta name="viewport" content="width=device-width, initial-scale=1.0" />
name="viewport"
content="width=device-width, initial-scale=1.0"
/>
<link rel="icon" type="image/svg+xml" href="/favicon.svg" /> <link rel="icon" type="image/svg+xml" href="/favicon.svg" />
{head.meta.map((m) => ( {head.meta.map((m) => (
@@ -31,5 +28,5 @@ export const RouterHead = component$(() => {
<style {...s.props} dangerouslySetInnerHTML={s.style} /> <style {...s.props} dangerouslySetInnerHTML={s.style} />
))} ))}
</> </>
) );
}) });

View File

@@ -7,10 +7,10 @@
* - https://qwik.builder.io/qwikcity/adaptors/cloudflare-pages/ * - https://qwik.builder.io/qwikcity/adaptors/cloudflare-pages/
* *
*/ */
import { createQwikCity } from '@builder.io/qwik-city/middleware/cloudflare-pages' import { createQwikCity } from '@builder.io/qwik-city/middleware/cloudflare-pages';
import qwikCityPlan from '@qwik-city-plan' import qwikCityPlan from '@qwik-city-plan';
import render from './entry.ssr' import render from './entry.ssr';
const onRequest = createQwikCity({ render, qwikCityPlan }) const onRequest = createQwikCity({ render, qwikCityPlan });
export { onRequest } export { onRequest };

View File

@@ -9,9 +9,9 @@
* - More code is transferred to the browser than in SSR mode. * - More code is transferred to the browser than in SSR mode.
* - Optimizer/Serialization/Deserialization code is not exercised! * - Optimizer/Serialization/Deserialization code is not exercised!
*/ */
import { render, RenderOptions } from '@builder.io/qwik' import { render, RenderOptions } from '@builder.io/qwik';
import Root from './root' import Root from './root';
export default function (opts: RenderOptions) { export default function (opts: RenderOptions) {
return render(document, <Root />, opts) return render(document, <Root />, opts);
} }

View File

@@ -10,11 +10,11 @@
* - https://vitejs.dev/config/preview-options.html#preview-options * - https://vitejs.dev/config/preview-options.html#preview-options
* *
*/ */
import { createQwikCity } from '@builder.io/qwik-city/middleware/node' import { createQwikCity } from '@builder.io/qwik-city/middleware/node';
import render from './entry.ssr' import render from './entry.ssr';
import qwikCityPlan from '@qwik-city-plan' import qwikCityPlan from '@qwik-city-plan';
/** /**
* The default export is the QwikCity adaptor used by Vite preview. * The default export is the QwikCity adaptor used by Vite preview.
*/ */
export default createQwikCity({ render, qwikCityPlan }) export default createQwikCity({ render, qwikCityPlan });

View File

@@ -10,9 +10,9 @@
* - npm run build * - npm run build
* *
*/ */
import { renderToStream, RenderToStreamOptions } from '@builder.io/qwik/server' import { renderToStream, RenderToStreamOptions } from '@builder.io/qwik/server';
import { manifest } from '@qwik-client-manifest' import { manifest } from '@qwik-client-manifest';
import Root from './root' import Root from './root';
export default function (opts: RenderToStreamOptions) { export default function (opts: RenderToStreamOptions) {
return renderToStream(<Root />, { return renderToStream(<Root />, {
@@ -23,5 +23,5 @@ export default function (opts: RenderToStreamOptions) {
lang: 'en-us', lang: 'en-us',
...opts.containerAttributes, ...opts.containerAttributes,
}, },
}) });
} }

View File

@@ -6,12 +6,11 @@
--user-font-scale: 1rem - 16px; --user-font-scale: 1rem - 16px;
--max-width: calc(100% - 1rem); --max-width: calc(100% - 1rem);
--font-body: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, --font-body: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif,
Helvetica, Arial, sans-serif, Apple Color Emoji, Segoe UI Emoji; Apple Color Emoji, Segoe UI Emoji;
--font-mono: 'IBM Plex Mono', Consolas, 'Andale Mono WT', 'Andale Mono', --font-mono: 'IBM Plex Mono', Consolas, 'Andale Mono WT', 'Andale Mono', 'Lucida Console',
'Lucida Console', 'Lucida Sans Typewriter', 'DejaVu Sans Mono', 'Lucida Sans Typewriter', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Liberation Mono',
'Bitstream Vera Sans Mono', 'Liberation Mono', 'Nimbus Mono L', Monaco, 'Nimbus Mono L', Monaco, 'Courier New', Courier, monospace;
'Courier New', Courier, monospace;
color-scheme: light; color-scheme: light;
--theme-accent: #006ce9; --theme-accent: #006ce9;

View File

@@ -1,12 +1,8 @@
import { component$ } from '@builder.io/qwik' import { component$ } from '@builder.io/qwik';
import { import { QwikCityProvider, RouterOutlet, ServiceWorkerRegister } from '@builder.io/qwik-city';
QwikCityProvider, import { RouterHead } from './components/router-head/router-head';
RouterOutlet,
ServiceWorkerRegister,
} from '@builder.io/qwik-city'
import { RouterHead } from './components/router-head/router-head'
import './global.css' import './global.css';
export default component$(() => { export default component$(() => {
/* /*
@@ -26,5 +22,5 @@ export default component$(() => {
<ServiceWorkerRegister /> <ServiceWorkerRegister />
</body> </body>
</QwikCityProvider> </QwikCityProvider>
) );
}) });

View File

@@ -1,11 +1,11 @@
import { component$, Slot, useStyles$ } from '@builder.io/qwik' import { component$, Slot, useStyles$ } from '@builder.io/qwik';
import type { DocumentHead } from '@builder.io/qwik-city' import type { DocumentHead } from '@builder.io/qwik-city';
import Menu from '~/components/menu/menu' import Menu from '~/components/menu/menu';
import OnThisPage from '~/components/on-this-page/on-this-page' import OnThisPage from '~/components/on-this-page/on-this-page';
import styles from './docs.css?inline' import styles from './docs.css?inline';
export default component$(() => { export default component$(() => {
useStyles$(styles) useStyles$(styles);
return ( return (
<div class="docs"> <div class="docs">
@@ -15,11 +15,11 @@ export default component$(() => {
</article> </article>
<OnThisPage /> <OnThisPage />
</div> </div>
) );
}) });
export const head: DocumentHead = ({ head }) => { export const head: DocumentHead = ({ head }) => {
return { return {
title: `${head.title} - Documentation`, title: `${head.title} - Documentation`,
} };
} };

View File

@@ -1,6 +1,6 @@
import { component$, Slot } from '@builder.io/qwik' import { component$, Slot } from '@builder.io/qwik';
import Footer from '~/components/footer/footer' import Footer from '~/components/footer/footer';
import Header from '~/components/header/header' import Header from '~/components/header/header';
export default component$(() => { export default component$(() => {
return ( return (
@@ -11,5 +11,5 @@ export default component$(() => {
</main> </main>
<Footer /> <Footer />
</> </>
) );
}) });

View File

@@ -7,12 +7,12 @@
* Qwik uses a service worker to speed up your site and reduce latency, ie, not used in the traditional way of offline. * Qwik uses a service worker to speed up your site and reduce latency, ie, not used in the traditional way of offline.
* You can also use this file to add more functionality that runs in the service worker. * You can also use this file to add more functionality that runs in the service worker.
*/ */
import { setupServiceWorker } from '@builder.io/qwik-city/service-worker' import { setupServiceWorker } from '@builder.io/qwik-city/service-worker';
setupServiceWorker() setupServiceWorker();
addEventListener('install', () => self.skipWaiting()) addEventListener('install', () => self.skipWaiting());
addEventListener('activate', () => self.clients.claim()) addEventListener('activate', () => self.clients.claim());
declare const self: ServiceWorkerGlobalScope declare const self: ServiceWorkerGlobalScope;

View File

@@ -1,10 +1,10 @@
/** @type {import('tailwindcss').Config} */ /** @type {import('tailwindcss').Config} */
const defaultTheme = require('tailwindcss/defaultTheme') const defaultTheme = require("tailwindcss/defaultTheme");
const colors = require('tailwindcss/colors') const colors = require("tailwindcss/colors");
module.exports = { module.exports = {
content: ['./src/**/*.{js,ts,jsx,tsx,mdx}'], content: ["./src/**/*.{js,ts,jsx,tsx,mdx}"],
theme: { theme: {
extend: { extend: {
colors: { colors: {
@@ -17,5 +17,5 @@ module.exports = {
}, },
}, },
plugins: [], plugins: [],
darkMode: 'class', darkMode: "class",
} };

View File

@@ -1,7 +1,7 @@
import { defineConfig } from 'vite' import { defineConfig } from 'vite';
import { qwikVite } from '@builder.io/qwik/optimizer' import { qwikVite } from '@builder.io/qwik/optimizer';
import { qwikCity } from '@builder.io/qwik-city/vite' import { qwikCity } from '@builder.io/qwik-city/vite';
import tsconfigPaths from 'vite-tsconfig-paths' import tsconfigPaths from 'vite-tsconfig-paths';
export default defineConfig(() => { export default defineConfig(() => {
return { return {
@@ -11,5 +11,5 @@ export default defineConfig(() => {
'Cache-Control': 'public, max-age=600', 'Cache-Control': 'public, max-age=600',
}, },
}, },
} };
}) });

View File

@@ -1,8 +1,9 @@
{ {
"name": "@bot-whatsapp/provider", "name": "@bot-whatsapp/provider",
"version": "0.0.7-alpha.0", "version": "0.0.1",
"description": "Esto es el conector a Twilio, Meta, etc...", "description": "Esto es el conector a Twilio, Meta, etc...",
"main": "./lib/mock/index.cjs", "main": "./lib/mock/index.cjs",
"private": true,
"keywords": [], "keywords": [],
"author": "", "author": "",
"license": "ISC", "license": "ISC",

View File

@@ -81,7 +81,7 @@ class TwilioProvider extends ProviderClass {
* @param {*} buttons [] * @param {*} buttons []
* @returns * @returns
*/ */
sendButtons = async () => { sendButtons = async (number, message, buttons = []) => {
console.log(``) console.log(``)
console.log( console.log(
`[NOTA]: Actualmente enviar botons con Twilio esta en desarrollo` `[NOTA]: Actualmente enviar botons con Twilio esta en desarrollo`

View File

@@ -1,7 +1,13 @@
const { Client, LocalAuth, MessageMedia, Buttons } = require('whatsapp-web.js') const {
Client,
LocalAuth,
MessageMedia,
Buttons,
List,
} = require('whatsapp-web.js')
const { ProviderClass } = require('@bot-whatsapp/bot') const { ProviderClass } = require('@bot-whatsapp/bot')
const { Console } = require('console') const { Console } = require('console')
const { createWriteStream } = require('fs') const { createWriteStream, existsSync } = require('fs')
const { const {
cleanNumber, cleanNumber,
generateImage, generateImage,
@@ -128,19 +134,19 @@ class WebWhatsappProvider extends ProviderClass {
* @param {*} buttons [] * @param {*} buttons []
* @returns * @returns
*/ */
// sendList = async (number, message, listInput = []) => { sendList = async (number, message, listInput = []) => {
// let sections = [ let sections = [
// { {
// title: 'sectionTitle', title: 'sectionTitle',
// rows: [ rows: [
// { title: 'ListItem1', description: 'desc' }, { title: 'ListItem1', description: 'desc' },
// { title: 'ListItem2' }, { title: 'ListItem2' },
// ], ],
// }, },
// ] ]
// let list = new List('List body', 'btnText', sections, 'Title', 'footer') let list = new List('List body', 'btnText', sections, 'Title', 'footer')
// return this.vendor.sendMessage(number, list) return this.vendor.sendMessage(number, list)
// } }
/** /**
* Enviar un mensaje solo texto * Enviar un mensaje solo texto

View File

@@ -1,123 +1,33 @@
const { writeFile, readFileSync } = require('fs') const { writeFile, readFileSync } = require('fs')
const { join } = require('path') const { join } = require('path')
const { execFile } = require('node:child_process')
const process = require('node:process')
const util = require('node:util')
const OS_ENVIROMENT_WIN = process.platform.includes('win32')
const semver = require('semver')
const NPM_COMMAND = OS_ENVIROMENT_WIN ? 'npm.cmd' : 'npm'
const [PKG_ARG, PKG_ARG_VERSION, NPM_TOKEN] = process.argv.slice(2) || [null]
const PATH_PACKAGES = join(__dirname, '..', `packages`) const PATH_PACKAGES = join(__dirname, '..', `packages`)
const [PKG_ARG, PKG_ARG_VERSION] = process.argv.slice(2) || [null]
const cmd = util.promisify(execFile)
/** /**
* Create Token * Actualizar ramdon version de package
*/
const npmToken = (token = null) =>
new Promise((resolve, reject) => {
writeFile(
`${process.cwd()}/.npmrc`,
`//registry.npmjs.org/:_authToken=${token}`,
(error) => {
if (error) reject(error)
resolve()
}
)
})
/**
* Leer package json
* @param {*} packageName * @param {*} packageName
* @returns
*/ */
const readPackage = (packageName = null) => { const updateVersion = (packageName = null, number = null) => {
if (!packageName) throw new Error(`PATH_ERROR_PACKAGE: ${packageName}`)
const pkgJson = join(PATH_PACKAGES, packageName, 'package.json') const pkgJson = join(PATH_PACKAGES, packageName, 'package.json')
const rawFile = readFileSync(pkgJson, 'utf-8') const rawFile = readFileSync(pkgJson, 'utf-8')
if (!rawFile) throw new Error(`ERROR_FILE_READ`) if (!rawFile) throw new Error(`ERROR_FILE_READ`)
let pkgJsonObject = JSON.parse(rawFile)
return JSON.parse(rawFile) const build = !number ? Date.now() : number
} let [versionNumber] = pkgJsonObject.version.split('-')
pkgJsonObject.version = !number ? `${versionNumber}-${build}` : `${number}`
/** pkgJsonObject = JSON.stringify(pkgJsonObject)
* Actualizar package json writeFile(pkgJson, pkgJsonObject, (err) => {
* @param {*} packageName if (err) throw err
* @param {*} newPkgJson
*/
const updatePackage = (packageName = null, newPkgJson) => {
return new Promise((resolve, reject) => {
const pkgJson = join(PATH_PACKAGES, packageName, 'package.json')
if (!Object.keys(newPkgJson).length) throw new Error(`ERROR_FILE_READ`)
writeFile(pkgJson, newPkgJson, (err) => {
if (err) reject(err)
resolve(true)
}) })
})
}
/**
* Actualizar version
* @param {*} packageName
*/
const updateVersion = async (packageName = null, number = null) => {
if (!packageName) throw new Error(`PATH_ERROR_PACKAGE: ${packageName}`)
const pkgJsonObject = readPackage(packageName)
const { version } = pkgJsonObject
const newVersion = !number
? semver.inc(version, 'prepatch', 'alpha')
: `${number}`
if (!semver.valid(newVersion))
throw new Error(`VERSION_ERROR: ${newVersion}`)
const newPkgJson = JSON.stringify(
{ ...pkgJsonObject, version: newVersion },
null,
2
)
await updatePackage(packageName, newPkgJson)
return { version: newVersion }
}
const packRelease = async (packageName) => {
const pkgJson = join(PATH_PACKAGES, packageName)
const { stdout } = await cmd(NPM_COMMAND, ['pack'], {
stdio: 'inherit',
cwd: pkgJson,
})
return stdout
}
const publishRelease = async (packageName, latest = null) => {
const args = !latest ? ['--tag', 'dev'] : ['--access', 'public']
const pkgJson = join(PATH_PACKAGES, packageName)
const { stdout } = await cmd(NPM_COMMAND, ['publish'].concat(args), {
stdio: 'inherit',
cwd: pkgJson,
})
console.log(stdout)
return stdout
} }
/** /**
* Recibe los argumentos entrantes * Recibe los argumentos entrantes
*/ */
if (PKG_ARG) {
const main = async () => {
if (PKG_ARG) {
const tokenNpm = NPM_TOKEN ? NPM_TOKEN.split('=').at(1) : null
const pkgName = PKG_ARG ? PKG_ARG.split('=').at(1) : null const pkgName = PKG_ARG ? PKG_ARG.split('=').at(1) : null
const pkgNumber = PKG_ARG_VERSION const pkgNumber = PKG_ARG_VERSION ? PKG_ARG_VERSION.split('=').at(1) : null
? PKG_ARG_VERSION.split('=').at(1) updateVersion(pkgName, pkgNumber)
: null
if (tokenNpm) await npmToken(tokenNpm)
await updateVersion(pkgName, pkgNumber)
await packRelease(pkgName)
await publishRelease(pkgName, pkgNumber)
}
} }
main()

View File

@@ -904,16 +904,7 @@ __metadata:
languageName: node languageName: node
linkType: hard linkType: hard
"@bot-whatsapp/bot@npm:*": "@bot-whatsapp/bot@*, @bot-whatsapp/bot@workspace:packages/bot":
version: 0.0.1
resolution: "@bot-whatsapp/bot@npm:0.0.1"
dependencies:
dotenv: ^16.0.3
checksum: 4a9e6e4e3793149f65a569a2b672a6c71aa5ca34e169ca2230b4617c268ee0cd68a9bf10311f7a856a514a55e63fba97c2257f796056c25c3881646cebb18107
languageName: node
linkType: hard
"@bot-whatsapp/bot@workspace:packages/bot":
version: 0.0.0-use.local version: 0.0.0-use.local
resolution: "@bot-whatsapp/bot@workspace:packages/bot" resolution: "@bot-whatsapp/bot@workspace:packages/bot"
dependencies: dependencies:
@@ -925,16 +916,7 @@ __metadata:
languageName: unknown languageName: unknown
linkType: soft linkType: soft
"@bot-whatsapp/cli@npm:*": "@bot-whatsapp/cli@*, @bot-whatsapp/cli@workspace:packages/cli":
version: 0.0.1
resolution: "@bot-whatsapp/cli@npm:0.0.1"
bin:
bot: bin/cli.js
checksum: f58373f5cc4014bc22664452d20ec676645d04ba95c4ea8525db1a6adafa3b183e403c72c8ff670670bad8b56be6da098cc6767c1bffffa086b76e987cf79e86
languageName: node
linkType: hard
"@bot-whatsapp/cli@workspace:packages/cli":
version: 0.0.0-use.local version: 0.0.0-use.local
resolution: "@bot-whatsapp/cli@workspace:packages/cli" resolution: "@bot-whatsapp/cli@workspace:packages/cli"
dependencies: dependencies:
@@ -947,17 +929,7 @@ __metadata:
languageName: unknown languageName: unknown
linkType: soft linkType: soft
"@bot-whatsapp/database@npm:*": "@bot-whatsapp/database@*, @bot-whatsapp/database@workspace:packages/database":
version: 0.0.1
resolution: "@bot-whatsapp/database@npm:0.0.1"
dependencies:
dotenv: ^16.0.3
mongodb: ^4.11.0
checksum: cc86a9a1117d5a3b4092f42cb138f8d04f6cacf0b9d6994a2c6f8ead7317c1d4acd8aee824ad4dfb4d6294646d1a32a49d37847d3b44bd35df86cdc18af675c4
languageName: node
linkType: hard
"@bot-whatsapp/database@workspace:packages/database":
version: 0.0.0-use.local version: 0.0.0-use.local
resolution: "@bot-whatsapp/database@workspace:packages/database" resolution: "@bot-whatsapp/database@workspace:packages/database"
dependencies: dependencies:
@@ -968,17 +940,7 @@ __metadata:
languageName: unknown languageName: unknown
linkType: soft linkType: soft
"@bot-whatsapp/provider@npm:*": "@bot-whatsapp/provider@*, @bot-whatsapp/provider@workspace:packages/provider":
version: 0.0.1
resolution: "@bot-whatsapp/provider@npm:0.0.1"
dependencies:
"@bot-whatsapp/bot": "*"
qr-image: ^3.2.0
checksum: 01ffa3f06ed90cffd4157b2c81b7ed705ffd708ca49cb2b051de767959b97c100b84ab0ae2f1c46407007e42e3bbb29ad04e074829041b048317939ebf6569ca
languageName: node
linkType: hard
"@bot-whatsapp/provider@workspace:packages/provider":
version: 0.0.0-use.local version: 0.0.0-use.local
resolution: "@bot-whatsapp/provider@workspace:packages/provider" resolution: "@bot-whatsapp/provider@workspace:packages/provider"
dependencies: dependencies:
@@ -1013,7 +975,6 @@ __metadata:
rollup: ^3.2.3 rollup: ^3.2.3
rollup-plugin-cleanup: ^3.2.1 rollup-plugin-cleanup: ^3.2.1
rollup-plugin-copy: ^3.4.0 rollup-plugin-copy: ^3.4.0
semver: ^7.3.8
standard-version: ^9.5.0 standard-version: ^9.5.0
uvu: ^0.5.6 uvu: ^0.5.6
languageName: unknown languageName: unknown
@@ -7676,7 +7637,7 @@ __metadata:
languageName: node languageName: node
linkType: hard linkType: hard
"semver@npm:^7.0.0, semver@npm:^7.1.1, semver@npm:^7.3.4, semver@npm:^7.3.5, semver@npm:^7.3.7, semver@npm:^7.3.8": "semver@npm:^7.0.0, semver@npm:^7.1.1, semver@npm:^7.3.4, semver@npm:^7.3.5, semver@npm:^7.3.7":
version: 7.3.8 version: 7.3.8
resolution: "semver@npm:7.3.8" resolution: "semver@npm:7.3.8"
dependencies: dependencies: