Dataviz as a codependency instead of prerrequisite.

This commit is contained in:
Offray Vladimir Luna Cárdenas 2016-02-24 11:03:53 +00:00
parent cd138d00af
commit 266d5378a1
4 changed files with 387 additions and 54 deletions

View File

@ -0,0 +1,132 @@
"
I'm just a way to explore Spec and its documentation for learning purposes.
"
Class {
#name : #DynamicDict,
#superclass : #ComposableModel,
#instVars : [
'data',
'list',
'content'
],
#category : #'Grafoscopio-UI'
}
{ #category : #'as yet unclassified' }
DynamicDict class >> defaultSpec [
<spec: #default>
^ SpecLayout composed
newRow: [:row |
row
add: #list right: 0.7;
add: #content left: 0.3];
yourself
]
{ #category : #accessing }
DynamicDict >> content [
^ content
]
{ #category : #accessing }
DynamicDict >> content: anObject [
content := anObject
]
{ #category : #accessing }
DynamicDict >> data [
data := {'first' -> 'I am just text' . 'second' -> 'ProfStef openPharoZenWorkspace' } asOrderedDictionary.
^ data
]
{ #category : #'as yet unclassified' }
DynamicDict >> initializePresenter [
list whenSelectedItemChanged: [:item |
item = 'first'
ifTrue: [ self rebuildWithTextLayoutFor: item ].
item = 'second'
ifTrue: [ self rebuildWithCodeLayoutFor: item ].
]
]
{ #category : #initialization }
DynamicDict >> initializeWidgets [
list := self newList.
list items: self data keys.
content := self newText.
self focusOrder
add: list;
add: content.
]
{ #category : #accessing }
DynamicDict >> list [
^ list
]
{ #category : #accessing }
DynamicDict >> list: anObject [
list := anObject
]
{ #category : #'as yet unclassified' }
DynamicDict >> rebuildWithCodeLayoutFor: key [
| newLayout |
content := GlamourPresentationModel new.
content presentationClass: GTPlayground startOn: (GTPlayPage new saveContent: (data at: key)).
newLayout := SpecLayout composed
newRow: [:row |
row
add: #list right: 0.7;
add: #content left: 0.3];
yourself.
self needRebuild: false.
content needRebuild: true.
Transcript show: 'código + ', self content asString, String cr.
self buildWithSpecLayout: newLayout.
]
{ #category : #'as yet unclassified' }
DynamicDict >> rebuildWithTextLayout [
| newLayout |
content := self newText.
newLayout := SpecLayout composed
newRow: [:row |
row
add: #list right: 0.7;
add: #content left: 0.3];
yourself.
self needRebuild: false.
list needRebuild: false.
content needRebuild: true.
Transcript show: 'texto + ', self content asString, String cr..
self buildWithSpecLayout: newLayout.
]
{ #category : #'as yet unclassified' }
DynamicDict >> rebuildWithTextLayoutFor: key [
| newLayout |
content := self newText text: (data at: key).
newLayout := SpecLayout composed
newRow: [:row |
row
add: #list right: 0.7;
add: #content left: 0.3];
yourself.
self needRebuild: false.
list needRebuild: false.
content needRebuild: true.
Transcript show: 'texto + ', self content asString, String cr..
self buildWithSpecLayout: newLayout.
]
{ #category : #api }
DynamicDict >> title [
^'Dynamic UI | test'
]

View File

@ -35,7 +35,7 @@ Class {
#category : #'Grafoscopio-UI' #category : #'Grafoscopio-UI'
} }
{ #category : #'as yet unclassified' } { #category : #configuration }
GrafoscopioBrowser class >> configureFossil [ GrafoscopioBrowser class >> configureFossil [
"Stablish where is located fossil according to the operative system and the input of the user" "Stablish where is located fossil according to the operative system and the input of the user"
| fileStream | | fileStream |
@ -46,7 +46,7 @@ GrafoscopioBrowser class >> configureFossil [
fossil := fileStream name asFileReference fullName. fossil := fileStream name asFileReference fullName.
] ]
{ #category : #'as yet unclassified' } { #category : #configuration }
GrafoscopioBrowser class >> configurePandoc [ GrafoscopioBrowser class >> configurePandoc [
"Stablish where is located pandoc according to the operative system and/or the input of the user" "Stablish where is located pandoc according to the operative system and/or the input of the user"
| fileStream | | fileStream |
@ -61,7 +61,7 @@ GrafoscopioBrowser class >> configurePandoc [
] ]
{ #category : #'as yet unclassified' } { #category : #configuration }
GrafoscopioBrowser class >> configureSettings [ GrafoscopioBrowser class >> configureSettings [
"Stablish several 'global' settings according to to image location and the operative system. For the moment we're gonna use hardcoded paths, "Stablish several 'global' settings according to to image location and the operative system. For the moment we're gonna use hardcoded paths,
but in the future this will be a smarter method finding the proper external tool and setting up it." but in the future this will be a smarter method finding the proper external tool and setting up it."
@ -84,23 +84,40 @@ GrafoscopioBrowser class >> configureSettings [
] ]
] ]
{ #category : #'as yet unclassified' } { #category : #'graphical interface' }
GrafoscopioBrowser class >> messageAbout [ GrafoscopioBrowser class >> messageAbout [
"Shows the author, license, sponsors and main contributors to the project and point to further documentation on the web" "Shows the author, license, sponsors and main contributors to the project and point to further documentation on the web"
UIManager default alert: UIManager default alert:
'Grafosocpio', '_.:| Grafoscopio |:._',
(String with: Character cr), (String with: Character cr),
'(c) Copyright 2014 by Offray Vladimir Luna Cárdenas', '(c) Copyright 2014-2016 by Offray Vladimir Luna Cárdenas',
(String with: Character cr), (String with: Character cr),
'Covered under MIT license.', 'Covered under MIT license.',
(String with: Character cr), (String with: Character cr),
(String with: Character cr), (String with: Character cr),
'SPONSORS:', '[ Sponsors ]',
(String with: Character cr), (String with: Character cr),
'mutabiT | www.mutabit.com ', 'mutabiT | www.mutabit.com ',
(String with: Character cr), (String with: Character cr),
'Fundación Universitaria Los Libertadores | www.ulibertadores.edu.co ', 'HiTec Lab, Fundación Universitaria Los Libertadores | www.ulibertadores.edu.co ',
(String with: Character cr),
(String with: Character cr),
'[ Thanks to ]',
(String with: Character cr),
'HackBo, Hackerspace Bogota | http://hackbo.co',
(String with: Character cr),
'// Regular workshops attendees \\
Rafael Medida, Iván Pulido, Camilo Hurtado',
(String with: Character cr),
'// Coffe talk (mostly about grafoscopio) \\
Yanneth Gil, Andrés Calderón, Luis Alejandro Bernal',
(String with: Character cr),
'// Pharo, Moose and Agile Visualization communities \\
Tudor Girba, Alexandre Bergel, Nicolai Hess, Peter Uhnák, Milton Mamani ',
(String with: Character cr),
'// Family support while writing, coding & travelling (among others!) \\
Divian Luna, Hilda Cárdenas',
(String with: Character cr), (String with: Character cr),
(String with: Character cr), (String with: Character cr),
'For further details and versions go to:', 'For further details and versions go to:',
@ -111,7 +128,7 @@ GrafoscopioBrowser class >> messageAbout [
title: 'About Grafoscopio'. title: 'About Grafoscopio'.
] ]
{ #category : #'as yet unclassified' } { #category : #'graphical interface' }
GrafoscopioBrowser class >> messageNoRecentDocuments [ GrafoscopioBrowser class >> messageNoRecentDocuments [
"Shows that a feature is not implemeted and point to further documentation on the web" "Shows that a feature is not implemeted and point to further documentation on the web"
@ -127,7 +144,7 @@ GrafoscopioBrowser class >> messageNoRecentDocuments [
title: 'No hay documentos recientes'. title: 'No hay documentos recientes'.
] ]
{ #category : #'as yet unclassified' } { #category : #'graphical interface' }
GrafoscopioBrowser class >> messageNotImplementedYet [ GrafoscopioBrowser class >> messageNotImplementedYet [
"Shows that a feature is not implemeted and point to further documentation on the web" "Shows that a feature is not implemeted and point to further documentation on the web"
@ -143,12 +160,12 @@ GrafoscopioBrowser class >> messageNotImplementedYet [
title: 'No implementado aún'. title: 'No implementado aún'.
] ]
{ #category : #'as yet unclassified' } { #category : #'graphical interface' }
GrafoscopioBrowser class >> open [ GrafoscopioBrowser class >> open [
^ self new open ^ self new open
] ]
{ #category : #'as yet unclassified' } { #category : #'graphical interface' }
GrafoscopioBrowser class >> openFromRecentlyUsed [ GrafoscopioBrowser class >> openFromRecentlyUsed [
"Tags the node passed as argument with a value from the collection of tags available" "Tags the node passed as argument with a value from the collection of tags available"
| selection | | selection |
@ -203,7 +220,7 @@ GrafoscopioBrowser class >> showSettings [
Transcript show: pandoc Transcript show: pandoc
] ]
{ #category : #'as yet unclassified' } { #category : #'graphical interface' }
GrafoscopioBrowser class >> startDockingBar [ GrafoscopioBrowser class >> startDockingBar [
"Creates a custom docking bar for grafoscopio on top, with shorcuts for most used actions, and a fixed place for asking for help. "Creates a custom docking bar for grafoscopio on top, with shorcuts for most used actions, and a fixed place for asking for help.
Some of the functionalities implemented now in the grafoscopio interface for document trees should be moved here, like the ones Some of the functionalities implemented now in the grafoscopio interface for document trees should be moved here, like the ones
@ -225,6 +242,7 @@ GrafoscopioBrowser class >> startDockingBar [
updateMenu := MenuMorph new. updateMenu := MenuMorph new.
updateMenu updateMenu
add: 'Grafoscopio' target: GrafoscopioBrowser selector: #updateGrafoscopio; add: 'Grafoscopio' target: GrafoscopioBrowser selector: #updateGrafoscopio;
add: 'Galeria de proyectos' target: GrafoscopioBrowser selector: #updateDataviz
add: 'Prerrequisitos' target: GrafoscopioBrowser selector: #updatePrerrequisites; add: 'Prerrequisitos' target: GrafoscopioBrowser selector: #updatePrerrequisites;
add: 'Documentación > Tutorial' target: GrafoscopioBrowser selector: #updateDocumentationTemp; add: 'Documentación > Tutorial' target: GrafoscopioBrowser selector: #updateDocumentationTemp;
add: 'Documentación > Toda' target: GrafoscopioBrowser selector: #updateDocumentation; add: 'Documentación > Toda' target: GrafoscopioBrowser selector: #updateDocumentation;
@ -252,7 +270,28 @@ GrafoscopioBrowser class >> startDockingBar [
openInWorld. openInWorld.
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updateDataviz [
"Updates Dataviz package with new versions of itself take from the source code repository and
the User Interface"
| update |
update := (UIManager default
question: '¿Desea actualizar la galería de proyectos'
title: 'Actualizar galeria de proyectos').
update ifNotNil: [
update
ifTrue: [
"Data visualization helpers"
Gofer new
smalltalkhubUser: 'Offray' project: 'Dataviz';
package: 'Dataviz';
load.
self inform: 'Actualización de galeria de proyectos terminada']
ifFalse: [self inform: 'Actualización de grafoscopio no realizada']]
]
{ #category : #updating }
GrafoscopioBrowser class >> updateDocumentation [ GrafoscopioBrowser class >> updateDocumentation [
"Updates documentation (manual, tutorials) from official repository" "Updates documentation (manual, tutorials) from official repository"
@ -289,7 +328,7 @@ GrafoscopioBrowser class >> updateDocumentation [
]. ].
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updateDocumentationOld [ GrafoscopioBrowser class >> updateDocumentationOld [
| localRepository remoteRepository | | localRepository remoteRepository |
@ -313,7 +352,7 @@ localRepository exists
] ]
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updateDocumentationTemp [ GrafoscopioBrowser class >> updateDocumentationTemp [
"Updates documentation (manual, tutorials) from official repository" "Updates documentation (manual, tutorials) from official repository"
@ -346,7 +385,7 @@ GrafoscopioBrowser class >> updateDocumentationTemp [
]. ].
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updateGrafoscopio [ GrafoscopioBrowser class >> updateGrafoscopio [
"Updates Grafoscopio with new versions of itself take from the source code repository and "Updates Grafoscopio with new versions of itself take from the source code repository and
the User Interface" the User Interface"
@ -363,7 +402,7 @@ GrafoscopioBrowser class >> updateGrafoscopio [
ifFalse: [self inform: 'Actualización de grafoscopio no realizada']] ifFalse: [self inform: 'Actualización de grafoscopio no realizada']]
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updateGrafoscopioScript [ GrafoscopioBrowser class >> updateGrafoscopioScript [
"Updates Grafoscopio with new versions of itself take from the source code repository and "Updates Grafoscopio with new versions of itself take from the source code repository and
the User Interface" the User Interface"
@ -374,7 +413,7 @@ GrafoscopioBrowser class >> updateGrafoscopioScript [
self updateUI. self updateUI.
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updatePrerrequisites [ GrafoscopioBrowser class >> updatePrerrequisites [
"Updates the system prerequisites with new versions of itself take from the source code repository" "Updates the system prerequisites with new versions of itself take from the source code repository"
| update | | update |
@ -392,7 +431,7 @@ GrafoscopioBrowser class >> updatePrerrequisites [
] ]
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updatePrerrequisitesScript [ GrafoscopioBrowser class >> updatePrerrequisitesScript [
"Updates the system prerequisites with new versions of itself take from the source code repository" "Updates the system prerequisites with new versions of itself take from the source code repository"
@ -400,7 +439,7 @@ GrafoscopioBrowser class >> updatePrerrequisitesScript [
Gofer it Gofer it
smalltalkhubUser: 'ObjectProfile' project: 'Roassal2'; smalltalkhubUser: 'ObjectProfile' project: 'Roassal2';
configurationOf: 'Roassal2'; configurationOf: 'Roassal2';
loadVersion: '1.15'. loadDevelopment.
"Support for the STON format used in file persistance for grafoscopio notebooks" "Support for the STON format used in file persistance for grafoscopio notebooks"
Gofer new Gofer new
@ -449,12 +488,6 @@ GrafoscopioBrowser class >> updatePrerrequisitesScript [
package: 'NBSQLite3-Examples'; package: 'NBSQLite3-Examples';
load. load.
"Data visualization helpers"
Gofer new
smalltalkhubUser: 'Offray' project: 'Dataviz';
package: 'Dataviz';
load.
"Support for Operative System integration" "Support for Operative System integration"
Gofer new Gofer new
squeaksource: 'OSProcess'; squeaksource: 'OSProcess';
@ -474,7 +507,7 @@ GrafoscopioBrowser class >> updatePrerrequisitesScript [
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updateSystem [ GrafoscopioBrowser class >> updateSystem [
"Updates the system with new versions of itself take from the source code repository" "Updates the system with new versions of itself take from the source code repository"
| update | | update |
@ -495,7 +528,7 @@ GrafoscopioBrowser class >> updateSystem [
] ]
{ #category : #'as yet unclassified' } { #category : #updating }
GrafoscopioBrowser class >> updateUI [ GrafoscopioBrowser class >> updateUI [
"Updates the User Interface (UI) with new versions of the docking bar or logos where available. Helpful while testing new functionality "Updates the User Interface (UI) with new versions of the docking bar or logos where available. Helpful while testing new functionality
that should be expossed to the user via the UI" that should be expossed to the user via the UI"
@ -622,8 +655,8 @@ GrafoscopioBrowser >> bodyIn: constructor [
{ #category : #'graphical interface' } { #category : #'graphical interface' }
GrafoscopioBrowser >> bodyIn: constructor for: aNode [ GrafoscopioBrowser >> bodyIn: constructor for: aNode [
"Shows the body in a constructor for selected node, if node is not tagged. If it is tagged it will return itself, so it can be rendered "Shows the body in a constructor for selected node, if node is not tagged.
properly for other messages" If it is tagged it will return itself, so it can be rendered properly for other messages"
| specialTags | | specialTags |

View File

@ -8,12 +8,12 @@ My main responsability is to provide grafoscopio with graphical widgets and othe
" "
Class { Class {
#name : #GrafoscopioGUI, #name : #GrafoscopioGUI,
#superclass : #ComposableModel, #superclass : #DynamicComposableModel,
#instVars : [ #instVars : [
'windowMainMenu', 'windowMainMenu',
'tree', 'tree',
'nodeHeader', 'nodeHeader',
'nodeDetails', 'nodeBody',
'headerRefreshProcess', 'headerRefreshProcess',
'selected' 'selected'
], ],
@ -40,12 +40,158 @@ GrafoscopioGUI class >> defaultSpec [
] right: 0.7; ] right: 0.7;
addSplitter; addSplitter;
newColumn: [ :nodePart | newColumn: [ :nodePart |
nodePart add: #nodeDetails] left: 0.3. nodePart add: #nodeBody] left: 0.3.
]. ].
]; ];
yourself yourself
] ]
{ #category : #examples }
GrafoscopioGUI class >> exampleBootstrapDynamicUI1 [
"Starting from an example UI from the Spec-Glamour, to customize towards the grafoscopio
UI and get some ideas"
|notebook leftUpperPanel leftPanel treeBrowser |
"Creating a notebook-tree with dummy data"
notebook := GrafoscopioNode new becomeDefaultTestTree.
"Defining the tree roots part"
leftUpperPanel := DynamicComposableModel new.
leftUpperPanel instantiateModels: #(tree TreeModel).
leftUpperPanel tree
roots: notebook children;
childrenBlock: [:node | node children ];
displayBlock: [:node | node title ].
leftUpperPanel layout: (SpecLayout composed
add: #tree;
yourself).
"to debug upto here uncomment the next line, and comment all other 'openWithSpec' ones"
"leftUpperPanel openWithSpec."
"Integrating the previous tree with the node header and creating the body according to
the tags on the node"
leftPanel := DynamicComposableModel new.
leftPanel assign: leftUpperPanel to: #roots.
leftPanel instantiateModels: #(header TextInputFieldModel).
treeBrowser := DynamicComposableModel new.
leftUpperPanel tree
whenSelectedItemChanged: [:node |
node
ifNil:[
leftPanel header text: ''.
treeBrowser instantiateModels: #(body TextModel).
Transcript show: 'Nada que mostrar', String cr]
ifNotNil: [
leftPanel header text: (leftUpperPanel tree selectedItem content header).
leftUpperPanel tree selectedItem content tags = 'código'
ifTrue: [
treeBrowser instantiateModels: #(body GlamourPresentationModel).
Transcript show: 'I am code', String cr.
Transcript show: treeBrowser body asString, String cr.
]
ifFalse: [
treeBrowser instantiateModels: #(body TextModel).
treeBrowser body text: (leftUpperPanel tree selectedItem content body).
Transcript show: 'I am NOT code', String cr.
Transcript show: treeBrowser body asString, String cr.
]
]
].
leftPanel layout:
(SpecLayout composed
newColumn: [:column |
column
add: #roots;
add: #header height: 35];
yourself).
"Integrating the previous tree with node body content"
treeBrowser assign: leftPanel to: #leftTree.
treeBrowser layout:
(SpecLayout composed
newRow: [:r | r add: #leftTree; add: #body ];
yourself
).
treeBrowser openWithSpec.
]
{ #category : #examples }
GrafoscopioGUI class >> exampleBootstrapDynamicUI2 [
"Starting from an example UI from the Spec-Glamour, to customize towards the grafoscopio
UI and get some ideas"
|notebook leftUpperPanel leftPanel treeBrowser |
"Creating a notebook-tree with dummy data"
notebook := GrafoscopioNode new becomeDefaultTestTree.
"Defining the tree roots part"
leftUpperPanel := DynamicComposableModel new.
leftUpperPanel instantiateModels: #(tree TreeModel).
leftUpperPanel tree
roots: notebook children;
childrenBlock: [:node | node children ];
displayBlock: [:node | node title ].
leftUpperPanel layout: (SpecLayout composed
add: #tree;
yourself).
"to debug upto here uncomment the next line, and comment all other 'openWithSpec' ones"
"leftUpperPanel openWithSpec."
"Integrating the previous tree with the node header and creating the body according to
the tags on the node"
leftPanel := DynamicComposableModel new.
leftPanel assign: leftUpperPanel to: #roots.
leftPanel instantiateModels: #(header TextInputFieldModel).
treeBrowser := DynamicComposableModel new.
leftUpperPanel tree
whenSelectedItemChanged: [:node |
node
ifNil:[
leftPanel header text: ''.
treeBrowser instantiateModels: #(body TextModel).
Transcript show: 'Nada que mostrar', String cr]
ifNotNil: [
leftPanel header text: (leftUpperPanel tree selectedItem content header).
leftUpperPanel tree selectedItem content tags = 'código'
ifTrue: [
treeBrowser instantiateModels: #(body GlamourPresentationModel).
treeBrowser assign: leftPanel to: #leftTree.
treeBrowser layout:
(SpecLayout composed
newRow: [:r | r add: #leftTree; add: #body ];
yourself
).
Transcript show: 'I am code', String cr.
Transcript show: treeBrowser body asString, String cr.
]
ifFalse: [
treeBrowser instantiateModels: #(body TextModel).
treeBrowser body text: (leftUpperPanel tree selectedItem content body).
treeBrowser assign: leftPanel to: #leftTree.
treeBrowser layout:
(SpecLayout composed
newRow: [:r | r add: #leftTree; add: #body ];
yourself
).
Transcript show: 'I am NOT code', String cr.
Transcript show: treeBrowser body asString, String cr.
]
]
].
leftPanel layout:
(SpecLayout composed
newColumn: [:column |
column
add: #roots;
add: #header height: 35];
yourself).
"Integrating the previous tree with node body content"
treeBrowser openWithSpec.
]
{ #category : #examples } { #category : #examples }
GrafoscopioGUI class >> exampleBootstrapUI [ GrafoscopioGUI class >> exampleBootstrapUI [
"Starting from an example UI from the Spec-Glamour, to customize towards the grafoscopio "Starting from an example UI from the Spec-Glamour, to customize towards the grafoscopio
@ -57,8 +203,9 @@ GrafoscopioGUI class >> exampleBootstrapUI [
ui title: 'new | Grafoscopio'. ui title: 'new | Grafoscopio'.
ui instantiateModels: #( ui instantiateModels: #(
tree TreeModel tree TreeModel
header TextModel header TextInputFieldModel
play GlamourPresentationModel). bodyWhenMarkup TextModel
bodyWhenCode GlamourPresentationModel).
notebook := GrafoscopioNode new becomeDefaultTestTree. notebook := GrafoscopioNode new becomeDefaultTestTree.
ui tree ui tree
roots: notebook children; roots: notebook children;
@ -74,7 +221,7 @@ GrafoscopioGUI class >> exampleBootstrapUI [
addHSplitter; addHSplitter;
newRow: #header bottom: 0.8] right: 0.7; newRow: #header bottom: 0.8] right: 0.7;
addVSplitter; addVSplitter;
newColumn: #play]; newColumn: #bodyWhenCode];
yourself. yourself.
ui openWithSpecLayout: lay. ui openWithSpecLayout: lay.
@ -100,23 +247,26 @@ GrafoscopioGUI >> initializeWidgets [
windowMainMenu := self windowMainMenu. windowMainMenu := self windowMainMenu.
tree := self tree. tree := self tree.
nodeHeader := self newTextInput. nodeHeader := self newTextInput.
nodeDetails := self newText. nodeBody :=
tree selectedItem
ifNotNil: [ self updateBody ]
ifNil: [nodeBody := self newText].
windowMainMenu applyTo: self. windowMainMenu applyTo: self.
self focusOrder self focusOrder
add: windowMainMenu; add: windowMainMenu;
add: tree; add: tree;
add: nodeHeader; add: nodeHeader;
add: nodeDetails. add: nodeBody.
] ]
{ #category : #accessing } { #category : #accessing }
GrafoscopioGUI >> nodeDetails [ GrafoscopioGUI >> nodeBody [
^ nodeDetails ^ nodeBody
] ]
{ #category : #accessing } { #category : #accessing }
GrafoscopioGUI >> nodeDetails: anObject [ GrafoscopioGUI >> nodeBody: anObject [
nodeDetails := anObject nodeBody := anObject
] ]
{ #category : #accessing } { #category : #accessing }
@ -233,8 +383,9 @@ GrafoscopioGUI >> tree [
tree whenHighlightedItemChanged: tree whenHighlightedItemChanged:
[tree selectedItem notNil [tree selectedItem notNil
ifTrue: [ ifTrue: [
Transcript show: tree selectedItem content header, String cr. self updateHeader.
self updateHeader] self updateBody.
]
]. ].
^ tree ^ tree
] ]
@ -244,9 +395,25 @@ GrafoscopioGUI >> tree: anObject [
tree := anObject tree := anObject
] ]
{ #category : #update }
GrafoscopioGUI >> updateBody [
"update the displayed content associated to the body of a node"
(tree selectedItem content tags = 'código')
ifTrue: [
^ nodeBody text: 'I should be playground because I am tagged as ', tree selectedItem content tags
]
ifFalse: [
"nodeBody := self newText."
^ nodeBody text: tree selectedItem content body
]
]
{ #category : #update } { #category : #update }
GrafoscopioGUI >> updateHeader [ GrafoscopioGUI >> updateHeader [
"update the displayed text associated to the header" "update the displayed text associated to the header of a node"
^ nodeHeader text: tree selectedItem content header. ^ nodeHeader text: tree selectedItem content header.

View File

@ -149,15 +149,16 @@ GrafoscopioNode >> becomeDefaultTestTree [
| node1 node2 node3 | | node1 node2 node3 |
self level: 0. self level: 0.
self header: 'Arbol principal'. self header: 'Arbol principal'.
node1 := GrafoscopioNode node1 := GrafoscopioNode new
header: 'Nodo 1' header: 'Nodo 1';
body: 'Texto 1'. body: 'Texto 1'.
node2 := GrafoscopioNode node2 := GrafoscopioNode new
header: 'Nodo 2' header: 'Nodo 2';
body: 'Texto 2'. body: 'Texto 2'.
node3 := GrafoscopioNode node3 := GrafoscopioNode new
header: 'Nodo 3' header: 'Nodo 3';
body: 'Texto 3'. body: 'ProfStef openPharoZenWorkspace';
tagAs: 'código'.
self self
addNode: node1; addNode: node1;
addNode: node2. addNode: node2.