diff --git a/ui/src/elements/how-document.ts b/ui/src/elements/how-document.ts index 1beacf0..7e940f7 100644 --- a/ui/src/elements/how-document.ts +++ b/ui/src/elements/how-document.ts @@ -41,6 +41,8 @@ import { CommentControl, Control } from "../controls"; @state() highlitRange : HilightRange | undefined; @state() overlapping : Comment[] | undefined @state() commentStats : CommentStats | undefined; + @state() availbleCollectionSections : Array = ["host_fn specs"] + private selectedCommentText: string = "" @query('how-new-section-dialog') @@ -461,6 +463,19 @@ import { CommentControl, Control } from "../controls"; @add-section=${this.addSection} sectionType=${SectionType.Content} > + ${this.availbleCollectionSections.length ? this.availbleCollectionSections.map(type => html` + { + console.log("FISH") + this.dispatchEvent(new CustomEvent('add-section', { detail: {name: type, contentType: "text/markdown", sectionType: SectionType.Content}, bubbles: true, composed: true })) + }} + > + + + `) : ""} ` } diff --git a/ui/src/elements/how-node.ts b/ui/src/elements/how-node.ts index ecadb09..4845e19 100644 --- a/ui/src/elements/how-node.ts +++ b/ui/src/elements/how-node.ts @@ -7,7 +7,7 @@ import {HowStore} from "../how.store"; import {ScopedElementsMixin} from "@open-wc/scoped-elements"; import { StoreSubscriber } from "@holochain-open-dev/stores"; import {unsafeHTML} from "lit/directives/unsafe-html.js"; -import { aliveImage } from "../images"; +import { aliveImage, underConstructionImage } from "../images"; const angleInRadians = (angleInDegrees: number) => (angleInDegrees - 90) * (Math.PI / 180.0); const polarToCartesian = (centerX:number, centerY:number, radius:number, angleInDegrees:number) => { @@ -125,14 +125,19 @@ export class HowNode extends ScopedElementsMixin(LitElement) { i+=1 } - if (this.state == SysState.Alive) { + if (this.flags.includes(UnitFlags.UnderConstruction)) { return html` -
- ` + ` + } else { - return html` -
${this.circle(segments)}
- ` + if (this.state == SysState.Alive) { + return html` + ` + } else { + return html` +
${this.circle(segments)}
+ ` + } } } else { return html` @@ -150,10 +155,6 @@ export class HowNode extends ScopedElementsMixin(LitElement) { img { width: 100%; } - .placeholder { - background-color: lightyellow; - border-radius: 50%; - } `, ]; } diff --git a/ui/src/elements/how-section.ts b/ui/src/elements/how-section.ts index 4a87030..0ae1fc3 100644 --- a/ui/src/elements/how-section.ts +++ b/ui/src/elements/how-section.ts @@ -53,6 +53,7 @@ export class HowSection extends ScopedElementsMixin(LitElement) { case SectionType.Content: return ""; break; case SectionType.Process: return html`Process Template` case SectionType.Requirement: return html`Required Section` + case SectionType.CollectionDef: return html`Collection Definition` } } diff --git a/ui/src/elements/how-unit.ts b/ui/src/elements/how-unit.ts index 70a56c3..717a9eb 100644 --- a/ui/src/elements/how-unit.ts +++ b/ui/src/elements/how-unit.ts @@ -19,6 +19,7 @@ import { InfoItem } from "./info-item"; import { HowConfirm } from "./how-confirm"; import { consume } from '@lit/context'; import { Profile, ProfilesStore, profilesStoreContext } from "@holochain-open-dev/profiles"; +import { underConstructionImage } from "../images"; const getCurrentStateName = (unit:Unit, documentState:string ): string => { for (const [procType, procName] of unit.processes) { @@ -123,6 +124,8 @@ export class HowUnit extends ScopedElementsMixin(LitElement) { const unitInfo: UnitInfo = this._unitsInfos.value[this.currentUnitEh] const action: Action = this._unitsActions.value[this.currentUnitEh] + const underConstruction = unit.meta.flags && unit.meta.flags.includes(UnitFlags.UnderConstruction) + const path = this.getPath() const docInfo = this._store.getCurrentDocument(path, this.currentUnitEh) let allDocs = this._store.getDocumentsFiltered(path, this.currentUnitEh , DocType.Document, false) @@ -149,7 +152,7 @@ export class HowUnit extends ScopedElementsMixin(LitElement) { updated = new Date(docInfo.updated) const document = docInfo.content state = document.state - if (isSteward && document.getStats().emptySections == 0) { + if (!underConstruction && isSteward && document.getStats().emptySections == 0) { controlsHTML = controlsHTML.concat(unit .nextStatesFrom(document.state) .map( @@ -164,13 +167,17 @@ export class HowUnit extends ScopedElementsMixin(LitElement) { } else { state = unitInfo.state } - if (state == SysState.Alive && isSteward) { + if ( (underConstruction || state == SysState.Alive) && isSteward) { controlsHTML.push(html` this.dispatchEvent(new CustomEvent('add-child', { detail: this.currentUnitEh, bubbles: true, composed: true }))} .info=${"add child"} .button=${"plus"}> - + + + `) + if (underConstruction && isSteward) { + controlsHTML.push(html` this.dispatchEvent(new CustomEvent('reparent', { detail: this.currentUnitEh, bubbles: true, composed: true }))} .info=${"reparent"} @@ -178,10 +185,13 @@ export class HowUnit extends ScopedElementsMixin(LitElement) { `) - if (updated) { - stateHTML = html`` - } else { - stateHTML = html`` + } + if (!underConstruction) { + if (updated) { + stateHTML = html`` + } else { + stateHTML = html`` + } } } else if (state == SysState.Defunct) { stateHTML = html`` @@ -232,9 +242,11 @@ export class HowUnit extends ScopedElementsMixin(LitElement) { .button=${"question"}>
- + ${ underConstruction ? + html`` : + html` `}
- ${unit.meta.flags.includes(UnitFlags.Placeholder) ? html`Under Construction` : ""} + ${underConstruction ? html`Under Construction` : ""} ${stateHTML}
${controlsHTML} diff --git a/ui/src/images.ts b/ui/src/images.ts index 5f201b6..e9c8fa2 100644 --- a/ui/src/images.ts +++ b/ui/src/images.ts @@ -1 +1,2 @@ +export const underConstructionImage = `data:image/svg+xml;charset=utf-8,${``.replace("#","%23")}` export const aliveImage = "" \ No newline at end of file diff --git a/ui/src/initHolochain.ts b/ui/src/initHolochain.ts index b165137..d414bdd 100644 --- a/ui/src/initHolochain.ts +++ b/ui/src/initHolochain.ts @@ -79,6 +79,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "Business, Legal, Finance, Regulatory", // max 25 charAgent stewards: [progenitor], // people who can change this document processes: std_procs, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["social.biz"], // full paths to parent nodes (remember it's a DAG) @@ -87,6 +88,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "Executive Function/ Council", // max 25 charAgent stewards: [progenitor], // people who can change this document processes: std_procs, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["social"], // full paths to parent nodes (remember it's a DAG) @@ -95,6 +97,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "Developer Engagement & Support", // max 25 charAgent stewards: [progenitor], // people who can change this document processes: std_procs, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["social.ops"], // full paths to parent nodes (remember it's a DAG) @@ -199,7 +202,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "Holochain Conductor", // max 25 char stewards: [progenitor], // people who can change this document processes: std_procs, - meta: {flags: `${UnitFlags.Placeholder}`}, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["tech.hc_framework.runtime.conductor"], // full paths to parent nodes (remember it's a DAG) @@ -208,7 +211,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "Holochain Conductor API", // max 25 char stewards: [progenitor], // people who can change this document processes: std_procs, - meta: {flags: `${UnitFlags.Placeholder}`}, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["tech.hc_framework.runtime.conductor"], // full paths to parent nodes (remember it's a DAG) @@ -217,7 +220,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "Holochain Conductor Services", // max 25 char stewards: [progenitor], // people who can change this document processes: std_procs, - meta: {flags: `${UnitFlags.Placeholder}`}, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["tech.hc_framework"], // full paths to parent nodes (remember it's a DAG) @@ -242,7 +245,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "User Interface", // max 25 char stewards: [progenitor], // people who can change this document processes: std_procs, - meta: {flags: `${UnitFlags.Placeholder}`}, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["tech.hc_framework.organism.organ"], // full paths to parent nodes (remember it's a DAG) @@ -259,7 +262,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "Shared Visibility", // max 25 char stewards: [progenitor], // people who can change this document processes: std_procs, - meta: {flags: `${UnitFlags.Placeholder}`}, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["tech.hc_framework.organism.organ"], // full paths to parent nodes (remember it's a DAG) @@ -268,7 +271,7 @@ export function initialTreeHolochain(progenitor: AgentPubKeyB64) { shortName: "DNA", // max 25 char stewards: [progenitor], // people who can change this document processes: std_procs, - meta: {flags: `${UnitFlags.Placeholder}`}, + meta: {flags: `${UnitFlags.UnderConstruction}`}, })], [SysState.Alive, new Unit({ parents: ["tech.hc_framework.organism.organ.cell"], // full paths to parent nodes (remember it's a DAG) @@ -733,7 +736,7 @@ function mintNFT(uint256 memory target_) external { }, { name: "host_fn spec", - sourcePath:"", + sourcePath: SourceManual, sectionType: SectionType.CollectionDef, contentType: "text/markdown", content: '{"description": "specification of host functions"}', diff --git a/ui/src/types.ts b/ui/src/types.ts index 7be0819..ebbf56c 100644 --- a/ui/src/types.ts +++ b/ui/src/types.ts @@ -286,7 +286,7 @@ export type UnitInfo = { } export enum UnitFlags { - Placeholder = "p" + UnderConstruction = "p" } export type UnitOutput = {