From 8478152831a4c08b1f15dcf91036a20f71378e73 Mon Sep 17 00:00:00 2001 From: Jay Ohms Date: Tue, 19 Sep 2023 12:25:36 -0400 Subject: [PATCH 1/3] Update package.json and other tweaks for publishing --- .gitignore | 6 ++++-- LICENSE | 2 +- bin/build.js | 2 +- package.json | 30 ++++++++++++++++++++++++------ 4 files changed, 30 insertions(+), 10 deletions(-) diff --git a/.gitignore b/.gitignore index 85fc3d8..b6da5d2 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,5 @@ -build -node_modules +/build +/dist +/node_modules *.log +package-lock.json diff --git a/LICENSE b/LICENSE index 61ec497..c9a8a15 100644 --- a/LICENSE +++ b/LICENSE @@ -1,4 +1,4 @@ -Copyright (c) 2022 37signals, LLC +Copyright (c) 2023 37signals LLC Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the diff --git a/bin/build.js b/bin/build.js index 8bb1f2c..196e7c3 100755 --- a/bin/build.js +++ b/bin/build.js @@ -3,7 +3,7 @@ const esbuild = require("esbuild") const package = require("../package.json") const year = new Date().getFullYear() -const banner = `/*\nStrada ${package.version}\nCopyright © ${year} 37signals, LLC\n*/` +const banner = `/*\nStrada ${package.version}\nCopyright © ${year} 37signals LLC\n*/` const options = { entryPoints: ["src/index.js"], diff --git a/package.json b/package.json index c872a2f..5f9290d 100644 --- a/package.json +++ b/package.json @@ -1,17 +1,35 @@ { "name": "@hotwired/strada", - "version": "0.9.3", + "version": "1.0.0-beta01", + "description": "Create fully native controls, driven by your web app.", "main": "dist/strada.js", "files": [ - "dist" + "dist/*.js" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/hotwired/strada-web.git" + }, + "keywords": [ + "hotwire", + "strada" + ], + "author": "37signals LLC", + "contributors": [ + "Jay Ohms " ], - "repository": "git://github.com/hotwired/strada-web.git", - "author": "37signals, LLC", "license": "MIT", + "bugs": { + "url": "https://github.com/hotwired/strada-web/issues" + }, + "homepage": "https://strada.hotwired.dev", + "publishConfig": { + "access": "public" + }, "scripts": { "clean": "rm -rf build/* dist/*", - "prebuild": "npm run clean", - "build": "bin/build.js" + "build": "bin/build.js", + "release": "yarn build && npm publish" }, "devDependencies": { "esbuild": "^0.17.16" From a43442c686a1689b41f935c9a6a5d100a5656572 Mon Sep 17 00:00:00 2001 From: Jay Ohms Date: Tue, 19 Sep 2023 12:27:22 -0400 Subject: [PATCH 2/3] Remove /dist from source control --- dist/strada.js | 205 ------------------------------------------------- 1 file changed, 205 deletions(-) delete mode 100644 dist/strada.js diff --git a/dist/strada.js b/dist/strada.js deleted file mode 100644 index c1d8be3..0000000 --- a/dist/strada.js +++ /dev/null @@ -1,205 +0,0 @@ -/* -Strada 0.9.3 -Copyright © 2023 37signals, LLC -*/ -var __defProp = Object.defineProperty; -var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; -var __publicField = (obj, key, value) => { - __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value); - return value; -}; - -// src/bridge.js -var Bridge = class { - #adapter; - #lastMessageId; - #pendingMessages; - #pendingCallbacks; - constructor() { - this.#adapter = null; - this.#lastMessageId = 0; - this.#pendingMessages = []; - this.#pendingCallbacks = /* @__PURE__ */ new Map(); - } - start() { - this.notifyApplicationAfterStart(); - } - notifyApplicationAfterStart() { - document.dispatchEvent(new Event("web-bridge:ready")); - } - supportsComponent(component) { - if (this.#adapter) { - return this.#adapter.supportsComponent(component); - } else { - return false; - } - } - send({ component, event, data, callback }) { - if (!this.#adapter) { - this.#savePendingMessage({ component, event, data, callback }); - return null; - } - if (!this.supportsComponent(component)) - return null; - const id = this.generateMessageId(); - const message = { id, component, event, data: data || {} }; - this.#adapter.receive(message); - if (callback) { - this.#pendingCallbacks.set(id, callback); - } - return id; - } - receive(message) { - this.executeCallbackFor(message); - } - executeCallbackFor(message) { - const callback = this.#pendingCallbacks.get(message.id); - if (callback) { - callback(message); - } - } - removeCallbackFor(messageId) { - if (this.#pendingCallbacks.has(messageId)) { - this.#pendingCallbacks.delete(messageId); - } - } - removePendingMessagesFor(component) { - this.#pendingMessages = this.#pendingMessages.filter((message) => message.component != component); - } - generateMessageId() { - const id = ++this.#lastMessageId; - return id.toString(); - } - setAdapter(adapter) { - this.#adapter = adapter; - document.documentElement.dataset.bridgePlatform = this.#adapter.platform; - this.adapterDidUpdateSupportedComponents(); - this.#sendPendingMessages(); - } - adapterDidUpdateSupportedComponents() { - if (this.#adapter) { - document.documentElement.dataset.bridgeComponents = this.#adapter.supportedComponents.join(" "); - } - } - #savePendingMessage(message) { - this.#pendingMessages.push(message); - } - #sendPendingMessages() { - this.#pendingMessages.forEach((message) => this.send(message)); - this.#pendingMessages = []; - } -}; - -// src/bridge_component.js -import { Controller } from "@hotwired/stimulus"; - -// src/bridge_element.js -var BridgeElement = class { - constructor(element) { - this.element = element; - } - get title() { - return (this.bridgeAttribute("title") || this.attribute("aria-label") || this.element.textContent || this.element.value).trim(); - } - get enabled() { - return !this.disabled; - } - get disabled() { - const disabled = this.bridgeAttribute("disabled"); - return disabled === "true" || disabled === this.platform; - } - enableForComponent(component) { - if (component.enabled) { - this.removeBridgeAttribute("disabled"); - } - } - hasClass(className) { - return this.element.classList.contains(className); - } - attribute(name) { - return this.element.getAttribute(name); - } - bridgeAttribute(name) { - return this.attribute(`data-bridge-${name}`); - } - setBridgeAttribute(name, value) { - this.element.setAttribute(`data-bridge-${name}`, value); - } - removeBridgeAttribute(name) { - this.element.removeAttribute(`data-bridge-${name}`); - } - click() { - if (this.platform == "android") { - this.element.removeAttribute("target"); - } - this.element.click(); - } - get platform() { - return document.documentElement.dataset.bridgePlatform; - } -}; - -// src/helpers/user_agent.js -var { userAgent } = window.navigator; -var isStradaNativeApp = /bridge-components: \[.+\]/.test(userAgent); - -// src/bridge_component.js -var BridgeComponent = class extends Controller { - static get shouldLoad() { - return isStradaNativeApp; - } - pendingMessageCallbacks = []; - initialize() { - this.pendingMessageCallbacks = []; - } - connect() { - } - disconnect() { - this.removePendingCallbacks(); - this.removePendingMessages(); - } - get component() { - return this.constructor.component; - } - get platformOptingOut() { - const { bridgePlatform } = document.documentElement.dataset; - return this.identifier == this.element.getAttribute(`data-controller-optout-${bridgePlatform}`); - } - get enabled() { - return !this.platformOptingOut && this.bridge.supportsComponent(this.component); - } - send(event, data = {}, callback) { - data.metadata = { - url: window.location.href - }; - const message = { component: this.component, event, data, callback }; - const messageId = this.bridge.send(message); - if (callback) { - this.pendingMessageCallbacks.push(messageId); - } - } - removePendingCallbacks() { - this.pendingMessageCallbacks.forEach((messageId) => this.bridge.removeCallbackFor(messageId)); - } - removePendingMessages() { - this.bridge.removePendingMessagesFor(this.component); - } - get bridgeElement() { - return new BridgeElement(this.element); - } - get bridge() { - return window.Strada.web; - } -}; -__publicField(BridgeComponent, "component", ""); - -// src/index.js -if (!window.Strada) { - const webBridge = new Bridge(); - window.Strada = { web: webBridge }; - webBridge.start(); -} -export { - BridgeComponent, - BridgeElement -}; From afa73f44be32f550f4121ab8cc64f49b70e64418 Mon Sep 17 00:00:00 2001 From: Jay Ohms Date: Tue, 19 Sep 2023 16:45:01 -0400 Subject: [PATCH 3/3] Change version to 1.0.0-beta1 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 5f9290d..d9162c7 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@hotwired/strada", - "version": "1.0.0-beta01", + "version": "1.0.0-beta1", "description": "Create fully native controls, driven by your web app.", "main": "dist/strada.js", "files": [