Welcome to TiddlyWiki created by Jeremy Ruston, Copyright © 2007 UnaMesa Association
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=45663
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=46604
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=46703
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=47023
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=47224
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=47243
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=47783
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=47883
11/29/2010 3:01 PMTuttle, David L.is the vendor invoice data feed to Accenture in production and working now?
Carpenter, Brian C.has been for a long time they just periodically want to send data to qa qhich is manual
3:17 PMTuttle, David L.I thought so - I can check it off my list
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=47963
<<mgtdList startTag:Project title:'Projects with no area' tags:'!Complete' view:Project mode:global
group:ProjectStatus
gView:bold
where:tiddler.hasNoParent('Area')
>>
<<mgtdList startTag:Action title:'You should give these actions a context' tags:'!Done' view:DoneAction mode:global
where:tiddler.hasNoParent('Context')
>>
<<mgtdList startTag:Action title:'Actions with no project' tags:'!Done' view:DoneAction mode:global
where:tiddler.hasNoParent('Project')
>>
WMS
- Re-design in Columbus
- Tampa in February
- Tampa requires SI changes
Byron rejected map design due to missing required fields.
- Required fields turned out to be PO information, and we do not use POs with HCR Manor Care.
- There was one additional issue that Priya will correct.
Issue:
Map had been built already, we did not adhere to SDLC steps.
- Priya will build a Unit Test Plan, but will not execute it due to not having any test files from maintenance
http://www.evernote.com/shard/s2/sh/422cac53-a82d-4933-ae93-b80c51f07c85/9adfff7232d007bc0bb6f1d09d7d4dea
https://www.evernote.com/Home.action#st=p&x=kronos&n=e1158576-8624-4598-931b-0050aed58c73
Kesav wants to test communications with Acosta ASAP. He would like to report such at this afternoon's meeting. I left text for Byron and voice mail on support phone. I want him to get on it, and let me know how long it will take.
810 is at Acosta and awaiting approval
850 made some additional changes per SAP team request (separate Journal Entry)
AS2 adapter built. Partnership not established. Waiting on network issue resolution. Target Testing tomorrow at 2:00 PM.
Thanks Haroon,
That was very helpful and very detailed.
Here is my response:
1. Message Type “ORDERS” vs “ORDCHG”
The test file that they provided was actually for an Order Change, which is why you received an ORDCHG message type. This is really an issue with the test data, not with the code. The code is working as expected and is doing what it is supposed to do. I’ll change the test data to be a New Order and re-process the file.
2. E1EDKA1 AG, please remove the LIFNR value
Ive made the change
3. E1EDKA1 WE Please remove the LIFNR value
Ive made the change
Im sending you a test file in the next 20mins with the requested corrections/changes.
Please review.
Result:
Issue was that SAP RP2 was not processing the data files. Files since 6/5 were in /pending directory. All of those files had been manually processed, except 6/11/2013. Spoke to Rekha, Phani, and Chandra about the issue. They are investing cause and will process the data.
595 UMBINBOUND NULL /UMB/inbox UMBINBOUND /Sap-RP1FI/outbox Y N Y NULL N N NULL NULL
3088 HBLLC1_UMBINBOUND NULL /UMB/inbox UMBINBOUND /Sap-RP2FI/outbox Y N Y NULL N N NULL NULL
3089 HBLLC2_UMBINBOUND NULL /UMB/inbox UMBINBOUND /Sap-RP2FI/outbox Y N Y NULL N N NULL NULL
1094 IBC-INBOUND-UMB-EDIDATA NULL /UMB/inbox UMB-INBOUND-EDIDATA /EDI-Typing/inbox Y N Y NULL N N NULL NULL
NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL
We are set to process the data once arrived in inbox.
Theory - We do not "get" data, and the process at UMB is not pushing the data to us.
Bryon & David -are you two available tomorrow morning at 9:45 for a call with UMB about the encashment file?
See phone number above.
-----Original Appointment-----
From: Lindsey, Gabby [mailto:gabby.lindsey@umb.com]
Sent: Monday, June 10, 2013 4:19 PM
To: Lindsey, Gabby; Tiller, Lee; Westerfield-Wallace, Paula R.
Subject: Hostess Brands Daily Paid / Enchashment File
When: Tuesday, June 11, 2013 9:45 AM-10:15 AM (UTC-06:00) Central Time (US & Canada).
Where: 1.866.537.1618 passcode 6822711
When: Tuesday, June 11, 2013 9:45 AM-10:15 AM (UTC-06:00) Central Time (US & Canada).
Where: 1.866.537.1618 passcode 6822711
Note: The GMT offset above does not reflect daylight saving time adjustments.
+~+~+~+~+~+~+~+~+~+
Daily Paid Files sent Tuesday-Saturday
Successful files sent 6/5-6/8 – Hostess received last file on 6/4
Hypothesis: Could be file name
XFER/ARS/INTBRAND/HBLLC1_UMBINBOUND_201306
Transfer log from 6/6/2013:
Transaction Process Transfer Remote Local Date Time
Number Name Status Node UserID (MM/DD/YYYY) HH:MM
_ I606300405 ARP04652 COMPLETE FILEREPO JASARP0 06/06/2013 00:47
ARS.ARS0465.ARP04652
Within this log is the following information:
Transaction Details:
More: +
Dataset name. . . . . . . ARS.ARS0465.ARP04652
Remote file name. . . . . /XFER/ARS/INTBRAND/HBLLC1_UMBINBOUND_201306
Remote system name. . . . FILEREPO
Remote IP Port. . . . . . 00000
Remote Trans Number . . . R606300802
NodeClass . . . . . . . . 000
NodeClassExec . . . . . . 000
Class of Service. . . . . COSDFLT
Record count. . . . . . . 000000000001
Byte count. . . . . . . . 000000000066
Compressed byte count . . 000000000000
Compression Ratio . . . .
Last message issued . . . PGTF3101I Activity I606300405 successfully
transferred 1 records with node FILEREPO 66
BYTES
Ahmed and Haroon working to get all interfaces ironed out.
Ahmed and Haroon working to get all interfaces ironed out.
Lean will test AS2 in production with us, and Acosta is planning to test on Thursday.
Ahmed comfortable with 850 data and format. He will confirm Haroon is equally comfortable and report. SAP was unavailable during afternoon, so testing was not able to be completed.
Assuming acceptance of the 810 by Acosta, we should be completed with Phase 0 deliverables on 6/13/2016 after AS2 String Test.
SAP needs additional data from the 945. Ahmed is working with the team to define the need and locate the data in the 945, if it is available.
Everything looks good, but more testing is warranted. Plan to complete this task by 6/14/2013.
1 Issue with Jacobson remains - likely firewall issue blocking outbound traffic
Kelly,
I know you've been out, so I wanted to make sure that you knew that your approval of the 810 is the only remaining checkpoint for that document.
Thanks,
David Tuttle
Lead - Applications Integration
Email: dtuttle@hostessbrandsllc.com
P: <span id="gc-number-0" class="gc-cs-link" title="Call with Google Voice">816-556-5023</span> | F: <span id="gc-number-0" class="gc-cs-link" title="Call with Google Voice">816-556-5066</span>
Hostess Brands, LLC
1 E. Armour Blvd
Kansas City, MO 64141
Conducted extensive testing of the EDI 944 inbound document from Jacobson.
Also, we requested additional test files from Jacobson. They have sent them in and we have been using them to test.
There are a few outstanding issues that need to be resolved:
(1) In situations where there is an over/under exception (such as damaged goods), the SAP team needs to develop some custom code that is triggered by the IDOC. Chintan is aware of this and has committed to getting it done by Tuesday morning.
(2) We have an outstanding question about whether we could have a situation in which there are 2 exceptions on the same line item. Example: They should have received a quanitity of 10, but only received 6 because 2 were damaged and 2 were shorted. We have this as an outstanding question to Jacobson and are waiting for a response.
(3) There is an outstanding question about how to handle overage. The SAP team has figured out how to handle shortage, but is unsure how to handle overage. Haroon has committed to working on this today and has reached out to Stefan with some questions. He has committed to getting this resolved by Mon morning.
The SAP team is looking into what is needed to the EDI 945 to trigger a batch/pick/pack in SAP. This is a new requirement that was brought up on Thursday.
This requires additional fields to be passed to them (ie mapping changes). They have identified "most" of the fields and we made the necessary changes and executed some tests. They are reviewing those tests and have committed to getting back to us by Monday morning.
Also, we requested additional test files from Jacobson. They have sent them in and we have been using them to test.
This despite having just confirmed usage of a ten-digit UPC
Update SO with Dates|Update SO Dates from Delivery|Enhancement|Amit Rana|6/14/2013|In Progress|Functional testing in progress
EDI 944 3PL Warehousing - Inbound: Received STO's|Interface|ER.72|Haroon Sheikh|6/21/2013|In Progress|Waiting on Chintan code for handling shortages/transfer posting
miscommunication and assumption on Ahmed's behalf.
Jacobson reported a few issues on Wednesday but they were quickly resolved and tested.
Unexpectedly received Retail Link Access
RETAIL LINK USER
YOUR USER ID IS: hos9174
YOUR PASSWORD IS: X8!lC2!q
These are confidential and MUST NOT BE SHARED WITH ANYONE in or outside of your company.
Your password will expire and you will be prompted to change it every 60 days for security purposes.
Any user who does not log into the site for a period greater than one year will have his or her user ID deleted.
TRAINING INFORMATION
On-Line training is available through the web site.
To access this information, select 'Get Support' from main Home Page.
Then select one of the links under the 'Training' section.
Help documentation is also available within 'Get Support' go to the 'Help Documentation' subheading and select 'Retail Link Help Desk Documentation' or any of the other links for additional documentation.
LOCAL USER GROUPS
Local Retail Link User's Group (RLUG) chapters offer regularly scheduled meetings where participants discuss how each company is using Retail Link to enhance their business.
These local meetings provide an excellent opportunity to share your experiences and to gather new ideas on how Retail Link can improve business.
To access User Group information, select 'Get Support' from the Home Page.
Then select the Retail Link User Group links from under the 'User Community' heading.
A listing of all RLUGs is available at 'Retail Link User Groups, Schedules and Meeting Notes'.
ASSISTANCE
We have provided many ways for you to get assistance with any tool or application available through our web site.
You may contact Retail Link Technical Support at 479-273-8888, OPTION 1.
Please be prepared to give your name and user ID immediately.
The hours for Retail Link Technical Support are Monday - Friday, 7:00 a.m. - 5:30 p.m. Central Time.
EMAIL RETAIL LINK TECHNICAL SUPPORT
There are several different email options available to you for support.
For additional access to your user ID or assistance with how your company is set up in Retail Link, you can email vendoraccess@wal-mart.com.
For assistance with data discrepancies, you can email rlinkhelp@wal-mart.com.
Please note that items sent via email for support will be responded to within 5-7 business days. If you have an issue that requires immediate assistance, please contact Technical Support via telephone.
Please be sure to include your name, company name, and user id in your message.
SEND FEEDBACK
The Send Feedback link provides an easy way of letting us know what you think about the new site.
What do you like? What would you like to see different?
Our Retail Link experts will answer your questions by email.
The Send Feedback link is located on the bottom of most pages in the center of the screen.
RETAIL LINK FORUM
Retail Link Forum provides a way for you to post questions to any Retail Link user.
Please be sure to read the Retail Link Forum Policies before posting.
Retail Link Forum is located under 'Get Support', under the 'Forum' subheading.
Wal-Mart Stores, Inc. Confidential
The website is: https://retaillink.wal-mart.com
You will not have full access for up to 24 hours.
This email and any files transmitted with it are confidential and intended solely for the individual or entity to whom they are addressed. If you have received this email in error destroy it immediately. *** Walmart Confidential ***
810 - There is 1 outstanding issue. Acosta has requested that we send them the SHIP FROM NAME (The name of the plant where the product is shipped from). Amit indicated that this will require custom code to be added and he sent an email (on Thursday morning) to Kelly (Acosta) asking if this is really required. He cc’d me on the email. Waiting on Acosta to respond to him.
Chintan completed the custom code to handle the over/under exceptions, however, we now have a new requirement from the SAP team to consolidate the exceptions as 1 item. In other words, they want us to add all the overages together and add all the underages together. This change has been developed and is actively being tested. Expected completion: COB today
The SAP team told us last week that they have a new requirement which is to use the EDI 945 to trigger a batch/pick/ship in SAP. This requires the map to deliver new/changed fields to them via the IDOC. (extensive mapping changes).
We received those new requirements yesterday (Wed) morning, but they were documented in a high-level (very brief) email which did not provide enough detail to move forward. I spoke to Haroom this morning and we went thought the details. I have a good understanding of the changes needed and am actively working on them. I willl deliver a test file to them in the next hour or so. Due to the nature of these changes, we will have to run numerous tests to test all the different scenarios. I expect we will be testing this all day tomorrow.
Also, testing the 945 is time consuming, because they have to create a 940 and a batch in SAP for each test, and then we can reply back with the 945.
Complted changes to Lead Load Plan & have received UAT from SAP on it current format. (from Byron Whitt)
BBI will validate their orders and handle timing exceptions by having access to Acosta systems.
All Oldco SI connects to NewCo SI now. Routing RP2 data from UMB as UMB>OGSI>NSI>RP2.
Lee Tiller is aware and has been provided copies of data files.
Tuttle, David L.
10:08 AM
I have a meeting with the new A/R supervisor in a few minutes. One of her discussion points is the 856. My question is will the 856 be the first, second, third, etc. interface that we tackle post go-live?
Polfliet, Stefan
10:08 AM
wave 1, together with jacobson inventory and STO Goods Issue
Tuttle, David L.
10:09 AM
k
thanks
Looks much better. I still see a couple things. Some of the things listed below may just be because this is test data but I am going to mention just in case.
The N1BT and N1ST 05 and 06 are missing on this example. It is my understanding you will be sending the 91 qualifier with SAP number as well as duns.
The N1RE 04 has same duns as the N1SF04. The last four digits of the N1SF04 should be the 4 digit plant code.
The N3 and N4 is missing for the Ship From Detail.
Terms are showing net 15 Net days 15 days out. Terms are Net 30, correct?
Swell Amount is showing as -1.65. I believe it will be -1.50.
TDS Amount? 7131.60
(504 x 16.50 = 8316.00) less swell (1.65 % on gross = 124.74) Total = 8191.26 – If there are other allowances coming off the gross price to = the lower total, those should be included in the data (detail level) so all matches.
_______________________________
Kelly O'Brien, EDI Analyst, Data Management Solutions
Missing mandatory data from Jacobson.
onenote:https://d.docs.live.net/d8953db1b4154c57/Documents/Vendors/Jacbobson.one#Re%20EDI%20940%20-%20Status%20Update§ion-id={172CAC8A-DE86-4C72-A688-02C79118808E}&page-id={283F1B47-040E-4AD6-9D6B-D84F48ABDF40}&end
https://skydrive.live.com/edit.aspx/Documents/Vendors?cid=d8953db1b4154c57&id=documents?&wd=target%28Jacbobson.one%7c172CAC8A-DE86-4C72-A688-02C79118808E%2fRe%3a%20EDI%20940%20-%20Status%20Update%7c283F1B47-040E-4AD6-9D6B-D84F48ABDF40%2f%29
Per Ahmed, they are still having issues with the 940 and will not address the 945 until the 940 issues are resolved.
Kelly,
I inquired about the REF*BM segment which includes the Bill Of Lading Number.
Amit Rana from our SAP team has just informed that the Invoices for Display Pallets do not contain the Bill Of Lading number, which is in the REF 02 (with BM qualifier).
The last test that we sent you was for an invoice for Display Pallets, which is why the REF*BM was not available to you.
How would you like to proceed?
Is there something that I can hard-code in that field, or a random number that I can generate on the EDI side?
Please advise.
Ahmed Sawan
Hostess Brands, LLC
Address: 1 E. Armour Blvd, Kansas City, MO 64141
Email: Ahmed.Sawan@interstatebrands.com
Phone: <span id="gc-number-1" class="gc-cs-link" title="Call with Google Voice">(704) 293-3068</span>
From: Rana, Amit
Sent: Thursday, July 11, 2013 1:25 PM
To: Sawan, Ahmed
Subject: RE: Acosta 810 - Issue with debit memo test data
debit memos won't have bill of lading...so you will have to leave blank for display pallet orders
--
Amit Rana
<span id="gc-number-1" class="gc-cs-link" title="Call with Google Voice">312.285.3325</span>
Sent email to request test complete by COB 7/12/2013
https://www.evernote.com/shard/s2/nl/117413/92fdf3d8-0bd0-447b-988b-0d7d4d23919b
https://www.evernote.com/shard/s2/nl/117413/5d18dd05-3311-4fb2-8fc3-e3d75b8ab545
https://www.evernote.com/shard/s2/nl/117413/8231b885-16dd-49b6-8c09-8f0e512d9b91
{{cols2{
{{col{
}}}
{{col{
}}}
}}}
Asked that we send separate certs for each leg in the authentication chain.
Hostess will use AS2 as communications protocol with ADP.
Acosta wants AS2 String Testing to occur on 6/13/2013
Enter projects and actions here. Click 'create these items' to create them.
Example usage:
{{{
Paint House
.Buy ladder and brushes|Errand
.Choose colours|Home|W
}}}
By default actions are next actions.
Specify W or F to make them future or Waiting For. You can create multiple projects and project-less actions.
You can also specify area for projects. Order dosn't matter, as there can only be one uniquely named tiddler. The following is valid:
{{{
Paint House|Home Maintenance|Personal
.Buy ladder and brushes|Errand
.Choose colours|W|Home
}}}
To specify multiple projects and tasks, along with project-less actions, the below is an example of one way create two projects with tasks, and then a stand alone action.
{{{
Clean up yard|Personal|Home Maintenance
.Pick up sticks|Weekend
.Bag all the sticks|Weekend
Check out latest SAN offerings|Research|Work
.Read up on all major vendors offerings|Reading
.Call Doug for opinion|Call
.Check budget|Work|F
.Call Tara about tickets
}}}
If you want to add an action to an already existing project, you can specify the project name to do so:
{{{
.Pick up lumber at Home Depot|Build toolshed|Errand
}}}
Honda of Tiffany Springs
Oil and Filter
Air Filter
Cabin Micron Filter
Alignment Check
Tire Air Pressure Adjustment
Sorry the URL is http://webas.hostessbrandsllc.com:9080/http/inbound/as2 (Forgot the LLC portion).
I apologize for any confusion. Anytime Thursday would work for me, my schedul is pretty open that day.
Thanks,
Byron
________________________________________
From: Georgina Mayfield
Sent: Monday, June 10, 2013 9:53 PM
To: Whitt, Byron
Subject: RE: AS2 Testing
OK, what time will work for you?
___________________________________________________________________________
Georgina K. Mayfield, Corporate Electronic Data Interchange Manager, Centralized Support
Office (864) 862-1518| Cell <span id="gc-number-2" class="gc-cs-link" title="Call with Google Voice"><span id="gc-number-2" class="gc-cs-link" title="Call with Google Voice">(864) 678-0515</span></span>
19 Grossmont Drive, Fountain Inn, SC 29644
gmayfield@acosta.com
Please consider the environment before printing this email.
From: Whitt, Byron [mailto:bwhitt@hostessbrandsllc.com]
Sent: Monday, June 10, 2013 10:53 PM
To: Georgina Mayfield
Subject: RE: AS2 Testing
Georgina,
I talked with Tuttle and said that Thursday would be fine.
Thanks,
Byron
________________________________________
From: Georgina Mayfield
Sent: Monday, June 10, 2013 6:47:15 PM
To: Whitt, Byron
Subject: RE: AS2 Testing
Byron,
Can this wait until Thursday? Kelly in on vacation and we are testing an upgrade this week. If not, Wednesday afternoon would be better for me.
___________________________________________________________________________
Georgina K. Mayfield, Corporate Electronic Data Interchange Manager, Centralized Support
Office (864) 862-1518| Cell (864) 678-0515
19 Grossmont Drive, Fountain Inn, SC 29644
gmayfield@acosta.com
Please consider the environment before printing this email.
From: Whitt, Byron [mailto:bwhitt@hostessbrandsllc.com]
Sent: Monday, June 10, 2013 5:34 PM
To: Georgina Mayfield
Cc: Tuttle, David
Subject: AS2 Testing
Georgina,
Would you have time tomorrow to schedule AS2 testing?
Server: http://webas.hostessbrands.com:9080/http/inbound/as2
Port: 9080
I have attached our cert.
Thanks,
Byron Whitt
{{cols2{
{{col{
<<tiddler 'Ticklers Requiring Action'>>
<<mgtdList
title:'Next Actions'
startTag:Action tags:'Next && !Done'
view:ActionProj
mode:global
where:tiddler.hasActiveProject()
newButtonTags:'Action Next'
>>
<<mgtdList
title:'Waiting Actions'
startTag:Action
tags:'[(Waiting For)] && !Done'
view:ActionProj
mode:global
where:tiddler.hasActiveProject()
newButtonTags:'Action [(Waiting For)]'
>>
}}}
{{col{
<<mgtdList
title:'Future Actions'
startTag:Action
tags:'Future && !Done'
view:ActionProj
mode:global
where:tiddler.hasActiveProject()
newButtonTags:'Action Future'
>>
{{scroll10{
<<mgtdList
title:'Done Actions'
startTag:Action
tags:'Done'
view:DoneAction
mode:global
newButtonTags:'Action Next Done'
sort:-modified
>>
}}}
}}}
}}}
{{cols2{
{{col{
<<tiddler 'Ticklers Requiring Action'>>
<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:Action mode:global
group:Contact
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action Next'
>>
<<mgtdList title:'Waiting Actions' startTag:Action tags:'[(Waiting For)] && !Done' view:Action mode:global
group:Contact
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action [(Waiting For)]'
>>
}}}
{{col{
<<mgtdList title:'Future Actions' startTag:Action tags:'Future && !Done' view:Action mode:global
group:Contact
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action Future'
>>
{{scroll10{
<<mgtdList title:'Done Actions' startTag:Action tags:'Done' view:DoneAction mode:global
group:Contact
gView:bold
sort:-modified
newButtonTags:'Action Next Done'
where:tiddler.hasActiveProject()
>>
}}}
}}}
}}}
{{cols2{
{{col{
<<tiddler 'Ticklers Requiring Action'>>
<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
group:Context
gView:Context
where:tiddler.hasActiveProject()
newButtonTags:'Action Next'
>>
<<mgtdList title:'Waiting Actions' startTag:Action tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
group:Context
gView:Context
where:tiddler.hasActiveProject()
newButtonTags:'Action [(Waiting For)]'
>>
}}}
{{col{
<<mgtdList title:'Future Actions' startTag:Action tags:'Future && !Done' view:ActionProj mode:global
group:Context
gView:Context
where:tiddler.hasActiveProject()
newButtonTags:'Action Future'
>>
{{scroll10{
<<mgtdList title:'Done Actions' startTag:Action tags:'Done' view:DoneAction mode:global
newButtonTags:'Action Next Done'
sort:-modified
>>
}}}
}}}
}}}
{{cols2{
{{col{
<<tiddler 'Ticklers Requiring Action'>>
<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:Action mode:global
group:Project
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action Next'
>>
<<mgtdList title:'Waiting Actions' startTag:Action tags:'[(Waiting For)] && !Done' view:Action mode:global
group:Project
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action [(Waiting For)]'
>>
}}}
{{col{
<<mgtdList title:'Future Actions' startTag:Action tags:'Future && !Done' view:Action mode:global
group:Project
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action Future'
>>
{{scroll10{
<<mgtdList title:'Done Actions' startTag:Action tags:'Done' view:DoneAction mode:global
group:Project
gView:bold
sort:-modified
newButtonTags:'Action Next Done'
where:tiddler.hasActiveProject()
>>
}}}
}}}
}}}
order:1
button:a
buttonLong:active
(shows active projects without a next action, sub-project or upcoming tickler)
<<mgtdList startTag:Project title:'You must assign a next action to these projects (or make them into Someday/Maybe)'
tags:'!Complete && !Someday/Maybe' view:Project mode:global
where:!tiddler.hasNextActionOrSubProjectOrTickler()
>>
https://adtppmus16ws2010.accenture.com/enigma/timesheet.aspx
Tuttle, David L.
11:28 AM
Have you got a test file for the 856 from Amit yet?
---------------------------------------------------------------------------Whitt, Byron N.
11:29 AM
They are evidentally having to develop code to get the shipper name in the IDOC
https://www.evernote.com/shard/s2/nl/117413/41377259-c960-4d78-a871-d5c5da610c73/
Additional capacity needed. Jacobson freezer not enough. Engaged Americold. Is there interfaces involved?
https://www.evernote.com/shard/s2/nl/117413/19abdf1a-4fa3-4b6c-b3c9-3fd3369bf087
20130625 - Sent email to Greg regarding contacting the Kronos technical interface contact.
RE: Kroger Advance Ship Notice (856)
https://www.evernote.com/shard/s2/nl/117413/19abdf1a-4fa3-4b6c-b3c9-3fd3369bf087
https://www.evernote.com/shard/s2/nl/117413/25349ebd-5b11-46c3-9cc0-ae3a0bdd47be
Venkat to determine if today (3/27/2015) or Monday (3/30/2015).
!!Actions
Done actions older than 14 days. <<deleteAllTagged 'Delete old actions' 'Action' '' 'Done' 'tiddler.olderThanDays(14)'>>
<<mgtdList title:'Done actions older than 14 days'
view:DoneAction
mode:global
sort:-modified
startTag:Action
tags:'Done'
where:'tiddler.olderThanDays(14)'
>>
!!Ticklers
Inactive ticklers older than 14 days. <<deleteAllTagged 'Delete old ticklers' 'Tickler' '' 'Actioned' 'tiddler.olderThanDays(14)'>>
<<mgtdList title:'Inactive ticklers older than 14 days'
startTag:Tickler
tags:'Actioned'
view:Tickler
mode:global
sort:-tickleDate
where:'tiddler.olderThanDays(14)'
>>
!!Projects
Completed projects older than 14 days. (Delete individually).
<<mgtdList title:'Completed projects older than 14 days'
mode:global
sort:-modified
startTag:Project
tags:'Complete'
view:ProjectComplete
where:'tiddler.olderThanDays(14)'
>>
/***
|Name:|CloseOnCancelPlugin|
|Description:|Closes the tiddler if you click new tiddler then cancel. Default behaviour is to leave it open|
|Version:|3.0.1 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#CloseOnCancelPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
merge(config.commands.cancelTiddler,{
handler_mptw_orig_closeUnsaved: config.commands.cancelTiddler.handler,
handler: function(event,src,title) {
this.handler_mptw_orig_closeUnsaved(event,src,title);
if (!story.isDirty(title) && !store.tiddlerExists(title) && !store.isShadowTiddler(title))
story.closeTiddler(title,true);
return false;
}
});
//}}}
Name: MptwTeal
Background: #fff
Foreground: #000
PrimaryPale: #B5D1DF
PrimaryLight: #618FA9
PrimaryMid: #1a3844
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #f8f8f8
TertiaryLight: #bbb
TertiaryMid: #999
TertiaryDark: #888
Error: #f88
<<saveChanges>>
<<search>>
<<closeAll>>
<<mgtdList
title:'Complete'
mode:global
startTag:Project
tags:'Complete'
view:ProjectComplete
group:day
gView:bold
gSort:-title
newButtonTags:'Project Complete'
sort:-modified
>>
Conference Bridge: <span id="gc-number-3" class="gc-cs-link" title="Call with Google Voice">888-810-4959</span> Passcode 4863389
Purpose: Obtain the information each party needs to setup the FTP site and confirm the filename that needs to be sent.
Agenda:
• Confirm IP Address, Passwords, Ports, etc for both TEST and PROD
o In January 2012, our firewall was opened to IP address 65.44.172.53 at Port 498
• Confirm filename that is to be sent
• What type of acknowledgment (if any) will be sent to confirm receipt of file
• Proposed timeline on when first test file can be sent via QA system
• Open Discussion
https://www.evernote.com/view/notebook/c21e8757-e352-4948-8de2-028d4d493d78?locale=en#n=c21e8757-e352-4948-8de2-028d4d493d78
<<tiddler 'MgtdSettings'>>
!!Theme
(Currently <<eval {{config.options.txtTheme}}>>)
<<selectTheme>>
{{tiny{
<slider Advanced>
[[modify menu|ConfigMenu]]
[[GTDComponent]]
</slider>
}}}
4/8/2015 11:40 AM - Amazon system is showing error. Colleen from Acosta indicated we should try later.
Need Byron to coach me on how to do this.
20130618 - No connection to HP2. Byron to touch base with Rob
Vistar is a VAN customer.
https://www.evernote.com/shard/s2/nl/117413/23d3b2f4-b936-4482-b343-3ea6c189bdfd/
https://www.evernote.com/shard/s2/nl/117413/2baa7305-282d-48d1-b187-1552cff2a37e/
https://www.evernote.com/shard/s2/nl/117413/900deeeb-a57c-40ee-865d-37e1e87a6f61
https://www.evernote.com/shard/s2/nl/117413/a15a19b8-a0f3-4cfd-b327-943958bd94eb
From Andee:
The file name that is generated from TradePro is 310_FFFRCAST_HostessProduction_YYYYMMDDnnnnnn.csv
From Brian:
Just call it TPM_forecast.csv on the Logility server.
Customer Master acknowledgment returned from Legacy AR system that is created when SAP Customer Master file is processed on AR system.
order:2
button:none
buttonLong:daily
<div macro="showWhenTagged 'Project'">[[TagDashboards##Project]]</div>
<div macro="showWhenTagged 'Context'">[[TagDashboards##Context]]</div>
<div macro="showWhenTagged 'Contact'">[[TagDashboards##Contact]]</div>
<div macro="showWhenTagged 'Area'">[[TagDashboards##Area]]</div>
<div macro="showWhenTagged 'Reference'">[[TagDashboards##Reference]]</div>
<div macro="showWhenTagged 'Ticklers Requiring Action'">[[TagDashboards##Ticklers Requiring Action]]</div>
<div macro="showWhenTagged 'Upcoming Ticklers '">[[TagDashboards##Upcoming Ticklers ]]</div>
https://www.evernote.com/shard/s2/nl/117413/10a7eb04-6ca9-4372-8205-eb180c8d51d4
/***
|''Name:''|DatePickerLibrary|
|''Description:''|DatePicker library for use with macros|
|''Author:''|Saq Imtiaz ( lewcid@gmail.com )|
|''Code Repository:''|http://svn.tiddlywiki.org/Trunk/contributors/SaqImtiaz/libraries/DatePicker.js|
|''Version:''|0.9|
|''Date:''|06/04/2007|
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|
|''~CoreVersion:''|2.3.0|
***/
// /%
//!BEGIN-PLUGIN-CODE
//{{{
function $id(n) {
return document.getElementById(n);
}
DatePicker = {
days : ['S','M','T','W','T','F','S'],
daysMon : ['M','T','W','T','F','S','S'],
cells : new Array(42),
setup : function(){
var cte = createTiddlyElement;
var table = this.table = cte(null,"table","datePickerTable");
table.style.display = 'none';
document.body.appendChild(table);
var thead = cte(table,"thead");
var hRow = cte(thead,"tr");
hRow.onclick = stopEvent;
cte(hRow,"td",null,"datePickerNav","<<").onclick = DatePicker.prevm;
cte(hRow,"td","datePickerMNS",null,null,{colSpan:"5"});
cte(hRow,"td",null,"datePickerNav",">>",{align:"right"}).onclick=DatePicker.nextm;
var tbody = cte(table,"tbody","datePickerTableBody");
var dayRow = cte(tbody,"tr",null,"datePickerDaysHeader");
for (var i=0; i<this.days.length; i++){
cte(dayRow,"td",null,null,this.days[i]);
}
},
show : function(el,dateObj,cb) {
var me = DatePicker;
var now = me.now = new Date();
if (!dateObj)
dateObj = now;
me.root = el;
if (cb)
me.root.datePickerCallback = cb;
me.scc = { m : now.getMonth(), y : now.getFullYear(), d : now.getDate() };
Popup.place(el,me.table,{x:0,y:1});
var cur = [dateObj.getDate(),dateObj.getMonth()+1,dateObj.getFullYear()];
me.cc = { m : cur[1]-1, y : cur[2] };
me.sd = { m : cur[1]-1, y : cur[2], d : cur[0] };
me.fillCalendar(cur[0],me.scc.d,cur[1]-1,cur[2]);
},
fillCalendar : function(hd,today,cm,cy) {
var me = DatePicker;
var monStart = config.mGTD.getOptChk('WeekStartsMonday');
var sd = me.now.getDate();
var td = new Date(cy,cm,1)
var cd = td.getDay();
$id('datePickerMNS').innerHTML = td.formatString('MMM YYYY')
var tbody = $id('datePickerTableBody');
removeChildren(tbody);
var dowRow = createTiddlyElement(tbody,"tr",null,"datePickerDowRow");
for (var d=0;d<=7;d++) {
// dow headings
createTiddlyElement(dowRow,"td",null,null,DatePicker[monStart?'daysMon':'days'][d]);
}
var days = (new Date(cy, cm+1, 0)).getDate();
var day = 1;
for (var j=1;j<=6;j++) { //rows
var row = createTiddlyElement(tbody,"tr",null,"datePickerDayRow");
for (var t=1; t<=7; t++) { //cells
var d = 7 * (j-1) - (-t) + (monStart ? 1 : 0); //id key
var is_this_month = ((d >= (cd -(-1))) && (d<=cd-(-(days))));
var dip = ( ((d-cd < sd) && (cm == me.scc.m) && (cy == me.scc.y)) || (cm < me.scc.m && cy == me.scc.y) || (cy < me.scc.y) );
var htd = ( (hd != '') && (d-cd == hd) );
var hToday = ( (today != '') && (d-cd == today) && cy == me.scc.y && cm == me.scc.m );
if (htd)
_class = 'highlightedDate';
else if (dip)
_class = 'oldDate';
else if (hToday && ! htd)
_class = 'todayDate';
else
_class = 'defaultDate';
if ((monStart && (t==6||t==7)) || (!monStart && (t == 1 || t == 7))) {
// weekend
_class += ' weekend';
}
if (!is_this_month) {
_class += ' otherMonth';
}
var cell = createTiddlyElement(row,"td","datePickerDay"+d,_class,(new Date(cy,cm,d-cd)).getDate());
cell.onmouseover = function(e){addClass(this,'tdover');};
cell.onmouseout = function(e){removeClass(this,'tdover');};
cell.onclick = me.selectDate;
me.cells[d] = new Date(cy,cm,d-cd);
day++;
}
if(day > days + cd)
break;
}
},
nextm : function() {
var me = DatePicker;
me.cc.m += 1;
if (me.cc.m >= 12) {
me.cc.m = 0;
me.cc.y++;
}
me.fillCalendar(me.getDayStatus(me.cc.m,me.cc.y),me.scc.d,me.cc.m,me.cc.y);
return false;
},
prevm : function() {
var me = DatePicker;
me.cc.m -= 1;
if (me.cc.m < 0) {
me.cc.m = 11;
me.cc.y--;
}
me.fillCalendar(me.getDayStatus(me.cc.m,me.cc.y),me.scc.d,me.cc.m,me.cc.y);
return false;
},
getDayStatus : function(ccm,ccy){
return (ccy == this.sd.y && ccm == this.sd.m)? this.sd.d : '';
},
selectDate : function(ev){
var e = ev ? ev : window.event;
var me = DatePicker;
var date = me.cells[resolveTarget(e).id.substring(13,resolveTarget(e).id.length)];
if (me.root.datePickerCallback && typeof me.root.datePickerCallback == 'function')
me.root.datePickerCallback(me.root,date);
$id('datePickerTable').style.display = 'none';
return false;
},
onclick : function(ev){
$id("datePickerTable").style.display = 'none';
return false;
},
create : function(el,dateObj,cb){
el.onclick = el.onfocus = function(e){DatePicker.show(el,dateObj,cb);stopEvent(e)};
},
css: "table#datePickerTable td.datePickerNav {\n"+
" cursor:pointer;\n"+
"}\n"+
"\n"+
".datePickerDaysHeader td {\n"+
" text-align:center;\n"+
" background:#ABABAB;\n"+
" font:12px Arial;\n"+
"}\n"+
"\n"+
".datePickerDayRow td {\n"+
" width:18px;\n"+
" height:18px;\n"+
"}\n"+
"\n"+
"td#datePickerMNS, td.datePickerNav {\n"+
" font:bold 13px Arial;\n"+
"}\n"+
"\n"+
"table#datePickerTable {\n"+
" position:absolute;\n"+
" border-collapse:collapse;\n"+
" background:#FFFFFF;\n"+
" border:1px solid #ABABAB;\n"+
" display:none; \n"+
"}\n"+
"\n"+
"table#datePickerTable td{\n"+
" padding: 3px;\n"+
"}\n"+
"\n"+
"td#datePickerMNS {\n"+
" text-align: center;\n"+
"}\n"+
"\n"+
"tr.datePickerDayRow td {\n"+
" background-color : #C4D3EA;\n"+
" cursor : pointer;\n"+
" border : 1px solid #6487AE;\n"+
" text-align : center;\n"+
" font : 10px Arial;\n"+
"}\n"+
"\n"+
"tr.datePickerDayRow td.defaultDate {\n"+
" color : #333333; \n"+
" text-decoration : none; \n"+
"}\n"+
"\n"+
"tr.datePickerDayRow td.emptyDate {\n"+
" cursor:default; \n"+
"}\n"+
"\n"+
"tr.datePickerDayRow td.oldDate {\n"+
" color : #ABABAB;\n"+
" text-decoration : line-through;\n"+
"}\n"+
"tr.datePickerDayRow td.highlightedDate {\n"+
" background : #FFF799;\n"+
" font-weight : bold;\n"+
" color : #333333;\n"+
"}\n"+
"\n"+
"tr.datePickerDayRow td.todayDate {\n"+
" font-weight : bold;\n"+
" color : red;\n"+
"}\n"+
"\n"+
"table#datePickerTable tr.datePickerDayRow td.tdover {\n"+
" background:#fc6;\n"+
"}",
init : function(){
this.setup();
addEvent(document,'click',DatePicker.onclick);
config.shadowTiddlers['StyleSheetDatePicker'] = this.css;
if(store)
store.addNotification('StyleSheetDatePicker',refreshStyles);
}
};
DatePicker.init();
//}}}
//!END-PLUGIN-CODE
// %/
WelcomeToTiddlyspot [[Next and Waiting Actions by Context]]
{{cols2{
{{col{
<<mgtdList
title:'Delegated/Waiting For'
startTag:Action
tags:'[(Waiting For)] && !Done'
view:ActionProj
mode:global
where:tiddler.getByIndex("Contact").length > 0'
group:Contact
gView:bold
newButtonTags:'Action [(Waiting For)]'
>>
}}}
{{col{
<<mgtdList title:'Done' startTag:Action tags:'Done && [(Waiting For)]' view:DoneAction mode:global
where:tiddler.getByIndex('Contact').length>0
group:Contact
gView:bold
newButtonTags:'Action Done [(Waiting For)]'
>>
}}}
}}}
/***
|Name|DeleteAllTaggedPlugin|
|Based on|http://ido-xp.tiddlyspot.com/#DeleteAllTaggedPlugin|
|Version|MGTD Hacked|
An adaptation of DeleteDoneTasks (Simon Baird) by Ido Magal
To use this insert {{{<<deleteAllTagged>>}}} into the desired tiddler.
Modified quite a bit by Simon for MonkeyGTD
Now only works with MgtdIndexedTags...
Example usage:
{{{<<deleteAllTagged>>}}}
<<deleteAllTagged>>
***/
//{{{
config.macros.deleteAllTagged = {
handler: function ( place,macroName,params,wikifier,paramString,tiddler ) {
var buttonTitle = params[0] ? params[0] : "Delete tiddlers tagged '"+tiddler.title+"'"; // simon's tweak
var tagToDelete = params[1] ? params[1] : tiddler.title;
var alsoDeleteThisTiddler = params[2] ? params[2] : "";
var tagExpr = params[3] ? params[3] : tagToDelete;
var whereExpr = params[4] ? params[4] : "true";
createTiddlyButton( place, buttonTitle, "Delete every tiddler tagged with '"+tiddler.title+"'",
this.deleteAllTagged( tagToDelete, alsoDeleteThisTiddler == "delete", tagExpr, whereExpr ));
},
deleteAllTagged: function(tag,deleteMe,tagExpr,whereExpr) {
return function() {
var collected = fastTagged(tag).filterByTagExpr('[['+tagExpr+']]').filterByEval(whereExpr).toTitleList();
if (collected.length == 0) {
alert( "None found." );
}
else {
if (confirm( "Found these tiddlers:\n'"
+ collected.join( "', '" ) + "'\n\n\n"
+ "Are you sure you want to delete these?" )) {
store.suspendNotifications();
for ( var i=0;i<collected.length;i++ ) {
store.removeTiddler( collected[i] );
story.closeTiddler( collected[i], true );
displayMessage( "Deleted '"+collected[i]+"'" );
}
store.resumeNotifications();
}
}
if (deleteMe) {
if (confirm("Also delete this tiddler, '"+tag+"'?")) {
store.removeTiddler( tag );
story.closeTiddler( tag, true );
displayMessage( "Deleted '"+tag+"'" );
}
}
}
}
};
//}}}
Byron indicated that there is an API that we will need to interface with. He is going to create a routing rule on the Heat Outbox to route Heat ticket files to trash for go-live. We will look to integrate with ZenDesk later.
https://www.evernote.com/shard/s2/nl/117413/41377259-c960-4d78-a871-d5c5da610c73/
[[Next Actions|Next Actions by Context]]
[[Starred Next Actions|Starred Next Actions]]
[[Next & Waiting Actions|Next and Waiting Actions by Context]]
[[Next & Waiting (Single Col)|Next and Waiting Actions by Context Single Col]]
[[Action Dashboard|Action Dashboard by Context]]
[[Starred Items]]
[[Tickler Dashboard]]
[[Tickler Dashboard by Contact]]
[[Delegated Tasks Dashboard]]
[[Reference Items]]
[[Done Actions]]
<slider+ Contexts>
<<mgtdList startTag:Action tags:'Next && !Done' groupCountOnly:yes group:Context gView:plain where:tiddler.hasActiveProject()>>
</slider>
<slider Grouped by Project>
[[Next Actions|Next Actions by Project]]
[[Next and Waiting Actions|Next and Waiting Actions by Project]]
[[Action Dashboard|Action Dashboard by Project]]
</slider>
<slider Grouped by Contact>
[[Next Actions|Next Actions by Contact]]
[[Next and Waiting Actions|Next and Waiting Actions by Contact]]
[[Action Dashboard|Action Dashboard by Contact]]
</slider>
<slider Ungrouped>
[[Next Actions]]
[[Next and Waiting Actions]]
[[Action Dashboard]]
</slider>
<slider All contexts>
<<mgtdList startTag:Context>>
</slider>
{{tiny{
<slider Advanced>
[[Mankoff Dash]]
[[modify menu|DoWorkMenu]]
[[GTDComponent]]
</slider>
}}}
<<mgtdList
title:'Done'
mode:global
startTag:Action
tags:'Done'
view:DoneAction
group:day
gView:DoneAction
gSort:-title
newButtonTags:'Action Next Done'
sort:-modified
>>
https://www.evernote.com/shard/s2/nl/117413/ac53e86e-5cb5-4c10-8f8c-9c0b76d7513e/
https://www.evernote.com/shard/s2/nl/117413/2a5e8697-2c1e-4d44-acd7-b3bfe31bf63f/
https://www.evernote.com/shard/s2/nl/117413/4a8f8b65-b643-4ecb-88ed-eeaed5f60ffb/
https://www.evernote.com/shard/s2/nl/117413/adb59018-382b-4f9a-a717-355096267af2/
https://sms-ibc.accenture.com/itg/project/ViewProject.do?projectId=48223
https://www.evernote.com/shard/s2/nl/117413/bf5dc27d-073f-4551-8da3-eae2a691045d
https://www.evernote.com/shard/s2/nl/117413/20a3464d-3b5a-4532-b5f4-084f6c2e60f7/
https://hostessbrandsllc.sharepoint.com/sites/Teams%20Landing/IT/Integration/Shared%20Documents/Forms/AllItems.aspx?RootFolder=%2Fsites%2FTeams%20Landing%2FIT%2FIntegration%2FShared%20Documents%2FEDI%2FTrading%20Partners%2FVistar&FolderCTID=0x012000D053D4F8C87A7540BC3354611DFCD0FD&View=%7BAABF3AC2-383E-4F48-964E-2DE2EE590E14%7D
Make map min/max = 10/10 to ensure data is accurate.
/***
|Name:|ExtentTagButtonPlugin|
|Description:|Adds a New tiddler button in the tag drop down|
|Version:|3.2 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#ExtendTagButtonPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
window.onClickTag_mptw_orig = window.onClickTag;
window.onClickTag = function(e) {
window.onClickTag_mptw_orig.apply(this,arguments);
var tag = this.getAttribute("tag");
var title = this.getAttribute("tiddler");
// Thanks Saq, you're a genius :)
var popup = Popup.stack[Popup.stack.length-1].popup;
createTiddlyElement(createTiddlyElement(popup,"li",null,"listBreak"),"div");
wikify("<<newTiddler label:'New tiddler' tag:'"+tag+"'>>",createTiddlyElement(popup,"li"));
return false;
}
//}}}
From Andee:
The file name that is generated from TradePro is 310_FFFRCAST_HostessProduction_YYYYMMDDnnnnnn.csv
From Brian:
Just call it TPM_forecast.csv on the Logility server.
https://www.evernote.com/shard/s2/nl/117413/f8c6d4f3-ed26-424f-a508-cbe3e6c4df8c/
https://www.evernote.com/shard/s2/nl/117413/900deeeb-a57c-40ee-865d-37e1e87a6f61
order:4
button:fortnight
buttonLong:fortnightly
message:%3C1F043D541FF08A4A9FF97DC275430F5C0EC1EC4E@048-CH1MPN1-183.048d.mgd.msft.net%3E
order:3
button:f
buttonLong:future
https://www.evernote.com/shard/s2/nl/117413/900deeeb-a57c-40ee-865d-37e1e87a6f61
https://www.evernote.com/shard/s2/nl/117413/9124b55f-45d1-4651-9070-3b437c1c9d13
https://www.evernote.com/shard/s2/nl/117413/2615a1b6-d616-4959-9d2a-4023460bfbdd
4/6 - Sent email to Richard, then Elizabeth when OOO email from Richard.
4/8/2015 4:18 PM - Sent email to Matt to get login credentials.
It looks like there already was an account setup. It is called hostess\svc-ftpusr. If you don’t have the password, let me know and I will get it over to you.
Logility Dev/QA server name is HBAPP02
Logility Prod server name is HBLOGAPP01
From Andee:
The file name that is generated from TradePro is 310_FFFRCAST_HostessProduction_YYYYMMDDnnnnnn.csv
From Brian:
Just call it TPM_forecast.csv on the Logility server.
Out of Scope - Not needed for go-live
BP to pull non-RFC files to oldco GIS from SAP RP2
/***
|Name:|HideWhenPlugin|
|Description:|Allows conditional inclusion/exclusion in templates|
|Version:|3.1 ($Rev: 3919 $)|
|Date:|$Date: 2008-03-13 02:03:12 +1000 (Thu, 13 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#HideWhenPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
For use in ViewTemplate and EditTemplate. Example usage:
{{{<div macro="showWhenTagged Task">[[TaskToolbar]]</div>}}}
{{{<div macro="showWhen tiddler.modifier == 'BartSimpson'"><img src="bart.gif"/></div>}}}
***/
//{{{
window.hideWhenLastTest = false;
window.removeElementWhen = function(test,place) {
window.hideWhenLastTest = test;
if (test) {
removeChildren(place);
place.parentNode.removeChild(place);
}
};
merge(config.macros,{
hideWhen: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( eval(paramString), place);
}},
showWhen: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( !eval(paramString), place);
}},
hideWhenTagged: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( tiddler.tags.containsAll(params), place);
}},
showWhenTagged: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( !tiddler.tags.containsAll(params), place);
}},
hideWhenTaggedAny: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( tiddler.tags.containsAny(params), place);
}},
showWhenTaggedAny: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( !tiddler.tags.containsAny(params), place);
}},
hideWhenTaggedAll: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( tiddler.tags.containsAll(params), place);
}},
showWhenTaggedAll: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( !tiddler.tags.containsAll(params), place);
}},
hideWhenExists: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( store.tiddlerExists(params[0]) || store.isShadowTiddler(params[0]), place);
}},
showWhenExists: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( !(store.tiddlerExists(params[0]) || store.isShadowTiddler(params[0])), place);
}},
hideWhenTitleIs: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( tiddler.title == params[0], place);
}},
showWhenTitleIs: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( tiddler.title != params[0], place);
}},
'else': { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
removeElementWhen( !window.hideWhenLastTest, place);
}}
});
//}}}
http://hondaoftiffanysprings.com/serviceRequest.asp
https://sites.accenture.com/groups/ADSPractices/default.aspx
Accenture ADM Needs Wizard
https://adswizard.accenture.com/#
SMS and Rationale
https://collaboration.accenture.com/display/ADTdoc/ADT+for+Outsourcing+Development+Usage+Practices+-+SCM
ADT Documentation
https://collaboration.accenture.com/pages/viewpage.action?pageId=65373950
/***
|Name:|InstantTimestampPlugin|
|Description:|A handy way to insert timestamps in your tiddler content|
|Version:|1.0.10 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#InstantTimestampPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Usage
If you enter {ts} in your tiddler content (without the spaces) it will be replaced with a timestamp when you save the tiddler. Full list of formats:
* {ts} or {t} -> timestamp
* {ds} or {d} -> datestamp
* !ts or !t at start of line -> !!timestamp
* !ds or !d at start of line -> !!datestamp
(I added the extra ! since that's how I like it. Remove it from translations below if required)
!!Notes
* Change the timeFormat and dateFormat below to suit your preference.
* See also http://mptw2.tiddlyspot.com/#AutoCorrectPlugin
* You could invent other translations and add them to the translations array below.
***/
//{{{
config.InstantTimestamp = {
// adjust to suit
timeFormat: 'DD/0MM/YY 0hh:0mm',
dateFormat: 'DD/0MM/YY',
translations: [
[/^!ts?$/img, "'!!{{ts{'+now.formatString(config.InstantTimestamp.timeFormat)+'}}}'"],
[/^!ds?$/img, "'!!{{ds{'+now.formatString(config.InstantTimestamp.dateFormat)+'}}}'"],
// thanks Adapted Cat
[/\{ts?\}(?!\}\})/ig,"'{{ts{'+now.formatString(config.InstantTimestamp.timeFormat)+'}}}'"],
[/\{ds?\}(?!\}\})/ig,"'{{ds{'+now.formatString(config.InstantTimestamp.dateFormat)+'}}}'"]
],
excludeTags: [
"noAutoCorrect",
"noTimestamp",
"html",
"CSS",
"css",
"systemConfig",
"systemConfigDisabled",
"zsystemConfig",
"Plugins",
"Plugin",
"plugins",
"plugin",
"javascript",
"code",
"systemTheme",
"systemPalette"
],
excludeTiddlers: [
"StyleSheet",
"StyleSheetLayout",
"StyleSheetColors",
"StyleSheetPrint"
// more?
]
};
TiddlyWiki.prototype.saveTiddler_mptw_instanttimestamp = TiddlyWiki.prototype.saveTiddler;
TiddlyWiki.prototype.saveTiddler = function(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created) {
tags = tags ? tags : []; // just in case tags is null
tags = (typeof(tags) == "string") ? tags.readBracketedList() : tags;
var conf = config.InstantTimestamp;
if ( !tags.containsAny(conf.excludeTags) && !conf.excludeTiddlers.contains(newTitle) ) {
var now = new Date();
var trans = conf.translations;
for (var i=0;i<trans.length;i++) {
newBody = newBody.replace(trans[i][0], eval(trans[i][1]));
}
}
// TODO: use apply() instead of naming all args?
return this.saveTiddler_mptw_instanttimestamp(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created);
}
// you can override these in StyleSheet
setStylesheet(".ts,.ds { font-style:italic; }","instantTimestampStyles");
//}}}
4/16/2015 - Requested test PO file from Leann Hammer
Nor can they "just overwrite" an order. Ahmed and Amit are working on issue. I sent email to Kelly at Acosta asking if they would return a 0 qty for a line if a product was removed from existing PO.
We have cases where Lean has assigned one delivery to more than one Load. Example:
[cid:e730b87b-a5ba-4a44-ae78-696d97ee8ea9]
I would guess some of these errors are due to the shifting around of orders and loads. However, it would be good to put in some checks and measures so they are caught or prevented more easily.
SAP currently hasn't accounted for 'LV' load void status. Hence if Lean voids a load, we have no way of knowing this. Our SAP developer is looking into us accepting LV status and deleting the load
We have a bunch of cases where Lean is trying to update loads that don't exist in SAP. Examples:
Lean ID SAP Shipment IDOC Issue
34032790 16373 Change to non-existant load
34032785 16375 Change to non-existant load
My guess is that either these Loads are invalid or they didn't get created for some reason SAP.
We have instances where Lean has already assigned deliveries to a Load and then sending updates to the Load by assigning new/more deliveries. A few examples are the following:
Lean ID SAP Shipment IDOC Issue
34124384 20000166 19723 Updating Load with new deliveries
34124384 20000166 19814 Updating Load with new deliveries
34127713 20000606 20142 Updating Load with new deliveries
34102685 20000116 20164 Updating Load with new deliveries
Once a Load has been planned and deliveries assigned to that Load, we should not add/remove more deliveries to the load. Void out the inaccurate Load and then send new Load with updated deliveries.
o New 943 map to give Jacobson visibility of each item by Pallet.
Requires a new map that uses E2EDL37 (Pallet Record) AND E2EDL24 (Case Level), instead of only E2EDL24. This requires the EDL37 record to be read through and then the E2EDL24 records assigned to E2EDL37 records.
https://www.evernote.com/shard/s2/nl/117413/3c33bd2a-d7a4-4a58-a2d6-f5a45c7f10f8
Sorry the URL is http://webas.hostessbrandsllc.com:9080/http/inbound/as2 (Forgot the LLC portion).
I apologize for any confusion.
Thanks,
Byron
________________________________________
From: Whitt, Byron
Sent: Tuesday, June 11, 2013 8:27 AM
To: Sawan, Ahmed; Torres, Ruel
Cc: Adkins, James; Glenn, Brian; Tuttle, David; Polfliet, Stefan
Subject: RE: Hostess - AS2 Connectivity
Ruel,
The AS2 connection should now be ready for testing.
URL: http://webas.hostessbrands.com:9080/http/inbound/as2
Inbound IP Address: 170.252.208.2
Inbound Port: 9080
Outboound IP Address: 170.252.42.38
I have attached our cert.
Thanks,
Byron
________________________________________
From: Whitt, Byron
Sent: Monday, June 10, 2013 12:50 PM
To: Sawan, Ahmed; Torres, Ruel
Cc: Adkins, James; Glenn, Brian; Tuttle, David; Polfliet, Stefan
Subject: RE: Hostess - AS2 Connectivity
Ruel,
Hopefully, I shoudl have that information to you tomorrow. We are making some changes tonight to our network configuration to resolve issues. I will provide the information as soon as we are able.
Thank,
Byron
________________________________________
From: Sawan, Ahmed
Sent: Monday, June 10, 2013 12:42 PM
To: Torres, Ruel; Whitt, Byron
Cc: Adkins, James; Glenn, Brian; Tuttle, David; Polfliet, Stefan
Subject: RE: Hostess - AS2 Connectivity
Thanks for following up Ruel.
Byron… Can you answer Ruel’s question about AS2 connectivity please?
- Ahmed
From: Torres, Ruel [mailto:Ruel.Torres@jacobsonco.com]
Sent: Monday, June 10, 2013 12:39 PM
To: Sawan, Ahmed; Polfliet, Stefan
Cc: Adkins, James; Glenn, Brian
Subject: RE: Hostess - AS2 Connectivity
Ahmed,
Do you have Hostess AS2 setup information available ? If not, when do you think you can get the information to us.
Please advise.
From: Glenn, Brian
Sent: Friday, May 24, 2013 10:28 AM
To: Sawan, Ahmed
Cc: Torres, Ruel; Adkins, James
Subject: RE: Hostess - AS2 Connectivity
Ahmed,
Sure. Attached is our AS2 information. We have a test and production EDI environment. If you are going to have both also, we can use the test info. If you are only going to have one environment then we can do our testing though out production environment. Let me know what works best for you.
Thanks,
Brian Glenn
Application Developer
Jacobson Companies
(o) <span id="gc-number-4" class="gc-cs-link" title="Call with Google Voice">515-299-6750</span>
From: Sawan, Ahmed [mailto:Ahmed.Sawan@interstatebrands.com]
Sent: Friday, May 24, 2013 9:06 AM
To: Glenn, Brian
Subject: Hostess - AS2 Connectivity
Hi Brian,
Can you help me with getting AS2 connectivity setup, or direct me to the appropriate person at Jacobson?
As you may already know, our new production hardware is not here yet, but we expect to have our production environment ready in the next few weeks.
Unfortunately, that means that I don’t have our IP/port information for that new server, but I will provide that as soon as it is available.
For now, I primarily need your IP Address and Port, so that we can start opening up firewalls on our end. This will ensure that we are not waiting on firewall changes down the road.
Thanks!
- Ahmed Sawan
RE: Kroger Advance Ship Notice (856)
December 2010
Brian has made a serious effort to change his people approach. He has attended a Dale Carnegie class, and it seems to have made a difference.
Brian went out of his way to lend support to the Kronos team during a recent priority 1 incident.
During the period, Brian successfully integrated a third node into the existing SI cluster.
Brian took the initiative to arrange SI training for IDC, on his own, without any directive from me.
Brian assumed the lead on the urgent Walmart/Millard project. He worked with Hostess leadership to ensure a smooth transition to Millard, and from Americold.
Brian took over the SI ALE issue, and resolved it within a couple of weeks. John Gray had worked on the problem for 3 months, and had made no measurable gains. Since the conversion to the RFC adapter, there have not been any issues with the SI to SAP adapter interfaces.
4. Delivery is assigned to two loads – As for this it looks like it may have been an updating issue. We updated load 34126181 to PO 0080000544.
2. Updating load with new deliveries – In my opinion there should be no additions to order quantities once a load has been created. If there are changes to the delivery location we need to be made aware of these but once a load has been created we should really not see these as the carrier has already been tendered the load.
1. Load Void – Are these really load voids or are these just date changes? If these are date changes we just need to be aware of what the date changes are and then we can adjust the load dates. My though is that Hostess is not really ‘cancelling’ it and reissuing a new one, there are just changes being made to the load dates. Please confirm.
https://www.evernote.com/shard/s2/nl/117413/7dac9334-df12-49a2-8cd6-085b18cce46a/
/***
|Name:|LessBackupsPlugin|
|Description:|Intelligently limit the number of backup files you create|
|Version:|3.0.1 ($Rev: 2320 $)|
|Date:|$Date: 2007-06-18 22:37:46 +1000 (Mon, 18 Jun 2007) $|
|Source:|http://mptw.tiddlyspot.com/#LessBackupsPlugin|
|Author:|Simon Baird|
|Email:|simon.baird@gmail.com|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Description
You end up with just backup one per year, per month, per weekday, per hour, minute, and second. So total number won't exceed about 200 or so. Can be reduced by commenting out the seconds/minutes/hours line from modes array
!!Notes
Works in IE and Firefox only. Algorithm by Daniel Baird. IE specific code by by Saq Imtiaz.
***/
//{{{
var MINS = 60 * 1000;
var HOURS = 60 * MINS;
var DAYS = 24 * HOURS;
if (!config.lessBackups) {
config.lessBackups = {
// comment out the ones you don't want or set config.lessBackups.modes in your 'tweaks' plugin
modes: [
["YYYY", 365*DAYS], // one per year for ever
["MMM", 31*DAYS], // one per month
["ddd", 7*DAYS], // one per weekday
//["d0DD", 1*DAYS], // one per day of month
["h0hh", 24*HOURS], // one per hour
["m0mm", 1*HOURS], // one per minute
["s0ss", 1*MINS], // one per second
["latest",0] // always keep last version. (leave this).
]
};
}
window.getSpecialBackupPath = function(backupPath) {
var now = new Date();
var modes = config.lessBackups.modes;
for (var i=0;i<modes.length;i++) {
// the filename we will try
var specialBackupPath = backupPath.replace(/(\.)([0-9]+\.[0-9]+)(\.html)$/,
'$1'+now.formatString(modes[i][0]).toLowerCase()+'$3')
// open the file
try {
if (config.browser.isIE) {
var fsobject = new ActiveXObject("Scripting.FileSystemObject")
var fileExists = fsobject.FileExists(specialBackupPath);
if (fileExists) {
var fileObject = fsobject.GetFile(specialBackupPath);
var modDate = new Date(fileObject.DateLastModified).valueOf();
}
}
else {
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
var file = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
file.initWithPath(specialBackupPath);
var fileExists = file.exists();
if (fileExists) {
var modDate = file.lastModifiedTime;
}
}
}
catch(e) {
// give up
return backupPath;
}
// expiry is used to tell if it's an 'old' one. Eg, if the month is June and there is a
// June file on disk that's more than an month old then it must be stale so overwrite
// note that "latest" should be always written because the expiration period is zero (see above)
var expiry = new Date(modDate + modes[i][1]);
if (!fileExists || now > expiry)
return specialBackupPath;
}
}
// hijack the core function
window.getBackupPath_mptw_orig = window.getBackupPath;
window.getBackupPath = function(localPath) {
return getSpecialBackupPath(getBackupPath_mptw_orig(localPath));
}
//}}}
/***
|''Name:''|LoadRemoteFileThroughProxy (previous LoadRemoteFileHijack)|
|''Description:''|When the TiddlyWiki file is located on the web (view over http) the content of [[SiteProxy]] tiddler is added in front of the file url. If [[SiteProxy]] does not exist "/proxy/" is added. |
|''Version:''|1.1.0|
|''Date:''|mar 17, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#LoadRemoteFileHijack|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
***/
//{{{
version.extensions.LoadRemoteFileThroughProxy = {
major: 1, minor: 1, revision: 0,
date: new Date("mar 17, 2007"),
source: "http://tiddlywiki.bidix.info/#LoadRemoteFileThroughProxy"};
if (!window.bidix) window.bidix = {}; // bidix namespace
if (!bidix.core) bidix.core = {};
bidix.core.loadRemoteFile = loadRemoteFile;
loadRemoteFile = function(url,callback,params)
{
if ((document.location.toString().substr(0,4) == "http") && (url.substr(0,4) == "http")){
url = store.getTiddlerText("SiteProxy", "/proxy/") + url;
}
return bidix.core.loadRemoteFile(url,callback,params);
}
//}}}
It looks like there already was an account setup. It is called hostess\svc-ftpusr. If you don’t have the password, let me know and I will get it over to you.
Logility Dev/QA server name is HBAPP02
Logility Prod server name is HBLOGAPP01
<<tabs txtMGTDMore
"Timeline" "Timeline" TabTimeline
"MGTD" "Configuration Options" ConfigMenu
"TW" "TiddlyWiki SideBar" TWSideBar
>>
<<tabs txtMGTDMain
"Work" "Do Work" DoWorkMenu
"Review" "Review" ReviewMenu
"Process" "Process Inbox" ProcessInboxMenu
"More..." "More..." MGTDMoreTab
>>
MPTW is a distribution or edition of TiddlyWiki that includes a standard TiddlyWiki core packaged with some plugins designed to improve usability and provide a better way to organise your information. For more information see http://mptw.tiddlyspot.com/.
https://www.evernote.com/shard/s2/res/ee27fb57-10b8-4211-bf35-9e7dae49e60e/scan_000001.pdf?search=Honda%20of%20Tiffany%20Springs
Document is completed and checked in to SharePoint. I have not yet sent to Rob as I sent email to Richard asking to confirm port.
https://hostessbrandsllc.sharepoint.com/sites/Teams%20Landing/IT/Integration/Shared%20Documents/EDI/Trading%20Partners/Aryzta(Cloverhill)/Firewall%20Change%20Request%20for%20Cloverhill.docx
https://www.evernote.com/shard/s2/nl/117413/eb755ece-954a-46dd-8614-fe0ef1bc3acd
(Contributed by Ken Mankoff)
{{cols2{
{{col{
<<mgtdList startTag:Action title:'Next' tags:'Next && !Done'
view:Action mode:global
group:Project
gView:bold
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !
Done' view:Action mode:global
group:Project
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action [(Waiting For)]'
>>
}}}
{{col{
<<mgtdList title:'Starred Actions' startTag:Starred tags:'Action && !
Done' view:ActionProj mode:global
group:ActionStatus
gView:bold
newButtonTags:'Starred Action'
>>
<<mgtdList title:'Starred Projects' startTag:Starred tags:'Project && !
Complete' view:Project mode:global
group:ProjectStatus
gView:bold
newButtonTags:'Starred Project'
>>
<<mgtdList title:'Other Starred Items' startTag:Starred tags:'!Project
&& !Action' view:star mode:global
group:GTDComponent
gView:bold
newButtonTags:'Starred'
>>
!!! Last 30 Modifications
<<timeline "modified" "30" "ddd, YYYY-0MM-0DD">>
}}}
}}}
merge(Array.prototype,{
each: function(func) {
for (var i=0;i<this.length;i++)
func(this[i]);
},
// TODO, there is a map in the core now. Is it same as this or different?
map: function(func) {
var result = [];
this.each(function(item) {
result.push(func(item));
});
return result;
},
select: function(func) {
var result = [];
this.each(function(item) {
if (func(item))
result.push(item);
});
return result;
},
reject: function(func) {
var result = [];
this.each(function(item) {
if (!func(item))
result.push(item);
});
return result;
}
});
//------------------------------------------
merge(String.prototype,{
parseTagExpr: function(debug) {
if (this.trim() == "")
return "(true)";
var logicOps = /(!|&&|\|\||\(|\))/g;
var spaced = this.
// because square brackets in templates are no good
// this means you can use [(With Spaces)] instead of [[With Spaces]]
replace(/\[\(/g," [[").
replace(/\)\]/g,"]] ").
// space things out so we can use readBracketedList. tricky eh?
replace(logicOps," $1 ");
var expr = "";
var tokens = spaced.readBracketedList(false); // false means not unique. nice one JR!
tokens.each(function(tok) {
if (tok.match(logicOps)) {
expr += tok;
}
else if (tok.match(/^parent:/)) {
// experimental
var lookForTagInParent = tok.split(":")[1];
expr += "tiddler.parents().anyHasTag('"+lookForTagInParent+"')";
}
else {
expr += "tiddler.tags.contains('%0')".format([
// fix single quote bug. hurrah
// but still have nasty round bracket bug
tok.replace(/'/,"\\'")
]);
}
});
if (debug)
alert(expr);
return '('+expr+')';
}
});
merge(Tiddler.prototype,{
matchesEvalExpr: function(evalExpr) {
var tiddler = this;
return eval(evalExpr);
},
matchesTagExpr: function(tagExpr) {
return this.matchesEvalExpr(tagExpr.parseTagExpr());
},
olderThanDays: function(days) {
return this.modified.getTime() < (new Date()).getTime() - days*1000*60*60*24;
}
});
//------------------------------------
merge(Tiddler.prototype,{
render: function(method,renderOptions) {
var renderMethod = "render_"+method;
if (this[renderMethod])
return this["render_"+method](renderOptions);
else
return "*** cant render "+renderMethod+" ***";
},
renderUtil: function(formatString,formatValues) {
return formatString.format(formatValues);
},
sorter: function(field) {
var sortMethod = "sort_"+field;
if (this[sortMethod])
return this[sortMethod]();
else
return this[field];
},
sorterUtil: function(otherTiddler,method) {
var desc = false;
if (method.substring(0,1) == "-") {
desc = true;
method = method.substring(1);
}
if (this.sorter(method) > otherTiddler.sorter(method))
return (desc ? -1 : +1);
else if (this.sorter(method) < otherTiddler.sorter(method))
return (desc ? +1 : -1);
else
return 0;
}
});
merge(String.prototype,{
sorterUtil: function(otherTiddler,method) {
var t1 = store.getTiddler(this);
var t2 = store.getTiddler(otherTiddler);
if (method.substring(0,1) == "-") {
desc = true;
}
if (t1 && t2)
return t1.sorterUtil(t2,method);
// this part is a little flakey but I'm aiming to
// put the None heading last in all cases
else if (t2)
return +1;
else if (t1)
return -1;
else {
// neither exist as tiddlers might as well compare strings
if (this < otherTiddler)
return (desc ? +1 : -1);
else if (this > otherTiddler)
return (desc ? -1 : +1);
else
return 0;
}
}
});
//------------------------------------------
merge(Array.prototype,{
// returns a hash
groupBy_hash: function(func) {
var result = {};
var leftOverGroup = '__NONE__';
this.each(function(item) {
var groups = func(item);
if (groups.length > 0) {
groups.each(function(group) {
if (!result[group])
result[group] = [];
result[group].push(item);
});
}
else {
if (!result[leftOverGroup])
result[leftOverGroup] = [];
result[leftOverGroup].push(item);
}
});
return result;
},
// returns an array of arrays, like Hash#sort in ruby
groupBy: function(func,itemSort,groupSort) {
if (!itemSort) itemSort = "title";
if (!groupSort) groupSort = "-title";
var result = this.groupBy_hash(func);
var sortedResult = [];
for (var g in result)
sortedResult.push([g,result[g].sort(function(a,b){return a.sorterUtil(b,itemSort);})]);
return sortedResult.sort(function(a,b){return a[0].sorterUtil(b[0],groupSort);});
},
// for convenience since it's mostly what we want
groupByTag: function(tag,itemSort,groupSort) {
return this.groupBy(function(t){return t.getByIndex(tag);},itemSort,groupSort);
}
});
//------------------------------------------
// for lists of tiddlers
merge(Array.prototype,{
filterByEval: function(evalExpr) {
return this.select(function(t) {
return t.matchesEvalExpr(evalExpr);
});
},
filterByTagExpr: function(tagExpr) {
return this.filterByEval(tagExpr.parseTagExpr());
},
filterGroupsByEval: function(evalExpr) {
// presumes the group name is a tiddler
return this.select(function(tGroup) {
var tiddler = store.getTiddler(tGroup[0]);
return tiddler && tiddler.matchesEvalExpr(evalExpr);
});
},
filterGroupsByTagExpr: function(tagExpr) {
return this.filterGroupsByEval(tagExpr.parseTagExpr());
},
render: function(renderMethod,renderOptions) {
return this.map(function(tiddler){
return tiddler.render(renderMethod,renderOptions);
}).join("\n");
},
renderGrouped: function(listRenderMethod,headingRenderMethod,noneHeading,renderOptions,groupCountOnly,nbTags) {
// do I ever use renderOptions??
// this lost some elegance when I shoehorned the groupCountOnly part in. todo refactor
// then lost some more with the nbTags addition...
// might need some reworking
var result = "";
this.each(function(g) {
var groupName = g[0];
var groupItems = g[1];
var showCount = "";
if (groupCountOnly && groupCountOnly != "")
showCount = groupItems.length > 0 ? " ("+groupItems.length+")" : "";
var makeHeading = (groupCountOnly&&groupCountOnly!="") ? "" : "!!";
var newButtonMarkup = "";
// this sucks
if (nbTags && nbTags != '') {
newButtonMarkup = " "+config.macros.mgtdList.getNewButton(nbTags + " [["+groupName+"]]");
}
if (groupName == "__NONE__") {
result = result + makeHeading + "{{noneHeading{[[("+(noneHeading?noneHeading:"No "+headingRenderMethod)+")]]}}}"+showCount+"\n";
}
else {
var gTiddler = store.getTiddler(groupName);
if (gTiddler) {
result = result + makeHeading+gTiddler.render(headingRenderMethod)+showCount+newButtonMarkup+"\n";
}
else {
result = result + makeHeading+"[["+groupName+"]]"+showCount+newButtonMarkup+"\n";
}
}
if (!groupCountOnly || groupCountOnly == "")
result = result + groupItems.render(listRenderMethod,renderOptions) + "\n";
});
if (groupCountOnly && groupCountOnly != "")
result = result.replace(/\n$/,''); // hack. remove trailing linefeed
return result;
},
tiddlerSort: function(sortBy) {
return this.sort(function(a,b) { return a.sorterUtil(b,sortBy); });
},
toTitleList: function() {
return this.map(function(t){return t.title;});
}
});
//------------------------------------------
config.options.txtTheme = 'MonkeyGTDTheme';
if (!config.mGTD) config.mGTD = {};
config.mGTD.specialTags = [
"Action",
"Project",
"Area",
//"Realm",
"Context",
"View",
"Tickler",
"Reference",
"Contact"
];
config.mGTD.tagsToIndex = [
"Action", // needed for action dependencies
"Project",
"Area",
"Realm",
"Context",
"ActionStatus",
"TicklerStatus",
"ProjectStatus",
"GTDComponent",
"Sidebar",
"Contact",
"TicklerRepeatType",
"Priority"
];
config.mgtdVersion = "3.1.8b";
config.macros.mgtdVersion={handler:function(place){wikify(config.mgtdVersion,place);}};
config.toggleTagAlwaysTouchModDate = true; // see ToggleTagPlugin
config.shadowTiddlers.SiteTitle = 'mGSD';
config.shadowTiddlers.SiteSubtitle = 'the tiddlywiki powered gtd system formerly known as MonkeyGTD';
config.mGTD.getOptChk = function(option) { return store.fetchTiddler('MgtdSettings').tags.contains(option); }
config.mGTD.getOptTxt = function(fieldName) { return store.fetchTiddler('MgtdSettings').fields[fieldName.toLowerCase()]; }
config.mGTD.setOptTxt = function(fieldName,fieldValue) { store.fetchTiddler('MgtdSettings').fields[fieldName.toLowerCase()] = fieldValue; }
// from tiddlytools.com/#CoreTweaks, thanks Eric
window.coreWikify = wikify;
window.wikify = function(source,output,highlightRegExp,tiddler)
{
if (source) arguments[0]=source.replace(/\\\\\n/mg,"<br>");
coreWikify.apply(this,arguments);
}
readOnly = false;
showBackstage = true;
merge(Date.prototype,{
addDay: function(n) { this.setDate( this.getDate() + n ); },
addWeek: function(n) { this.setDate( this.getDate() + n*7 ); },
addFortnight: function(n) { this.setDate( this.getDate() + n*14 ); },
addMonth: function(n) { this.setMonth( this.getMonth() + n ); },
addYear: function(n) { this.setYear( this.getFullYear() + n ); }
});
// it works in view mode, that's why we can't just use edit macro
merge(config.macros, {
mgtdEditField: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var fieldName = params[0];
var useTiddler = tiddler;
if (params[1])
useTiddler = store.fetchTiddler(params[1]);
var curVal = useTiddler.fields[fieldName] || '';
var editBox = createTiddlyElement(place,'input',null,'editBox');
editBox.value = curVal;
var callback = function(){
useTiddler.fields[fieldName] = this.value;
useTiddler.touch(); // see MgtdDateUtils
}
editBox.onchange = callback;
}
}
});
function wikifiedMessage(message) {
wikify(message,getMessageDiv());
}
merge(config.macros,{
help: {
handler: function (place,macroName,params,wikifier,paramString,tiddler) {
createTiddlyButton(place,"?","help",function() {
var useThis = params[0]?params[0]:tiddler.title;
var help = store.getTiddlerText("MonkeyGTDHelp##"+useThis);
help = help?help:"//No help for <nowiki>"+useThis+"</nowiki>//";
var helpContent = "{{help{\n''[[MonkeyGTD Documentation|http://www.tiddlywiki.org/wiki/MonkeyGTD]]''\n" +
"!<nowiki>" + useThis + "</nowiki>\n" +
help + "\n\n" +
"[[More...|http://www.tiddlywiki.org/wiki/MonkeyGTD/"+useThis+"]]" +
"\n}}}\n" +
"";
// doesn't work at all. I have no idea how to use TW popups apparently ...
//var popup = Popup.create(place,"div","popupTiddler");
//wikify(helpContent,popup,null,tiddler);
//Popup.show();
// stick with this for now
clearMessage();
wikifiedMessage(helpContent);
return false;
});
}
}
});
config.indexedTags = {
// will be populated with our tag lists
tagLists: {},
// will be populated with our tag indexes
indexes: {},
// will be populated with the tags that need indexing
tagsToIndex: [],
saveTiddlerHijack: function(title,newTitle,newBody,modifier,modified,tags,fields) {
var before = store.getTiddler(title);
var oldTags = before ? [].concat(before.tags) : null; // concat so we get a dup
store.suspendNotifications();
var result = this.saveTiddler_orig_indexedTags(title,newTitle,newBody,modifier,modified,tags,fields);
var newTags = store.getTiddler(newTitle).tags;
config.indexedTags.updateTagLists(title,oldTags,newTitle,newTags);
config.indexedTags.updateIndexes(title,newTitle,newTags);
store.resumeNotifications();
store.notify(title,true);
return result;
},
removeTiddlerHijack: function(title) {
var before = store.getTiddler(title);
var oldTags = before ? [].concat(before.tags) : null; // concat so we get a dup
store.suspendNotifications();
this.removeTiddler_orig_indexedTags(title);
config.indexedTags.updateTagLists(title,oldTags);
config.indexedTags.updateIndexes(title);
store.resumeNotifications();
store.notify(title,true);
},
setTiddlerTagHijack: function(title,status,tag) {
clearMessage(); // unrelated to indexedTags but....
var before = store.getTiddler(title);
var oldTags = before ? [].concat(before.tags) : null; // concat so we get a dup
store.suspendNotifications();
this.setTiddlerTag_orig_indexedTags(title,status,tag);
var after = store.getTiddler(title);
var newTags = after ? after.tags : null;
config.indexedTags.updateTagLists(title,oldTags,title,newTags);
config.indexedTags.updateIndexes(title,title,newTags);
store.resumeNotifications();
store.notify(title,true);
},
updateTagLists: function(title,oldTags,newTitle,newTags) {
if (oldTags)
oldTags.each(function(tagName) {
if (!config.indexedTags.tagLists[tagName])
config.indexedTags.tagLists[tagName] = []; // fixes TiddlerEncryption/MTS, thanks Patrick Ohly.
config.indexedTags.tagLists[tagName].remove(title);
});
if (newTags)
newTags.each(function(tagName) {
if (!config.indexedTags.tagLists[tagName])
config.indexedTags.tagLists[tagName] = [];
config.indexedTags.tagLists[tagName].pushUnique(newTitle);
});
},
updateIndexes: function(title,newTitle,newTags) {
delete config.indexedTags.indexes[title];
if (newTags) {
config.indexedTags.indexes[newTitle] = {};
config.indexedTags.tagsToIndex.each(function(tagToIndex) {
config.indexedTags.indexes[newTitle][tagToIndex] = [];
newTags.each(function(tag) {
if (config.indexedTags.tagLists[tagToIndex] && config.indexedTags.tagLists[tagToIndex].contains(tag)) {
config.indexedTags.indexes[newTitle][tagToIndex].pushUnique(tag);
}
});
});
}
},
initTagLists: function() {
store.getTags().map(function(pair) { return pair[0]; }).each(function(t) {
config.indexedTags.tagLists[t] = store.getTaggedTiddlers(t).map(function(tt) { return tt.title; });
});
},
initIndexes: function() {
store.forEachTiddler(function(title,tiddler) {
config.indexedTags.updateIndexes(title,title,tiddler.tags);
});
},
dump: function() {
alert(this.indexes["Buy petrol for mower"]["Project"]);
alert(this.indexes["Buy petrol for mower"]["Realm"]);
},
tiddlerMethods: {
getByIndex: function(tag) {
return config.indexedTags.indexes[this.title][tag];
},
hasParent: function(tag) {
return this.getByIndex(tag).length > 0
},
hasNoParent: function(tag) {
return !this.hasParent(tag);
},
hasActiveProject: function() {
var projs = this.getByIndex("Project");
if (projs.length == 0)
// no project but we will say it's active
// because otherwise it will not show up anywhere
return true;
for (var i=0;i<projs.length;i++)
if (
(config.indexedTags.indexes[projs[i]]['ProjectStatus'].contains('Active'))
&&
!store.fetchTiddler(projs[i]).tags.contains('Complete') // seems stupid
)
return true;
return false;
},
hasStarredProject: function() {
// similar to hasActiveProject
// thanks to Bernhardt Rainer
var projs = this.getByIndex("Project");
if (projs.length == 0)
return false;
for (var i=0;i<projs.length;i++)
if (
(config.indexedTags.indexes[projs[i]]['ProjectStatus'].contains('Starred'))
&&
!store.fetchTiddler(projs[i]).tags.contains('Complete') // seems stupid
)
return true;
return false;
},
getAreasForAction: function() {
// we will go to some trouble to permit actions in multiple areas
// either explicitly or via their project...
// also permit multiple projects......
// explicit:
var result = [];
result = result.concat(this.getByIndex("Area"));
// implicit (via project/s):
var projs = this.getByIndex("Project");
for (var i=0;i<projs.length;i++)
result = result.concat(store.fetchTiddler(projs[i]).getByIndex("Area"));
return result;
},
hasNextAction: function() {
var children = fastTagged(this.title).filterByTagExpr('Action && !Done && (Next || [(Waiting For)])');
return children.length > 0;
},
hasTickler: function() {
var children = fastTagged(this.title).filterByTagExpr('Tickler && !Actioned');
return children.length > 0;
},
hasSubProject: function() {
var children = fastTagged(this.title).filterByTagExpr('Project && !Complete && Active');
return children.length > 0;
},
hasNextActionOrSubProject: function() {
return (this.hasSubProject() || this.hasNextAction());
},
hasNextActionOrSubProjectOrTickler: function() {
return (this.hasSubProject() || this.hasNextAction() || this.hasTickler());
}
},
globalMethods: {
fastTagged: function(tag) {
var list = config.indexedTags.tagLists[tag];
return (list?list:[]).map(function(t){return store.getTiddler(t);});
}
},
init: function(tagsToIndex) {
merge(window,this.globalMethods);
merge(Tiddler.prototype,this.tiddlerMethods);
this.tagsToIndex = tagsToIndex;
this.initTagLists();
this.initIndexes();
TiddlyWiki.prototype.saveTiddler_orig_indexedTags = TiddlyWiki.prototype.saveTiddler;
TiddlyWiki.prototype.removeTiddler_orig_indexedTags = TiddlyWiki.prototype.removeTiddler;
TiddlyWiki.prototype.setTiddlerTag_orig_indexedTags = TiddlyWiki.prototype.setTiddlerTag;
TiddlyWiki.prototype.saveTiddler = this.saveTiddlerHijack;
TiddlyWiki.prototype.removeTiddler = this.removeTiddlerHijack;
TiddlyWiki.prototype.setTiddlerTag = this.setTiddlerTagHijack;
}
};
config.indexedTags.init(config.mGTD.tagsToIndex);
merge(Tiddler.prototype,{
// doesn't belong here..
ticklerIsActive: function() {
var defaultHourToActivate = 5; // fixme put elsewhere
var hourToActivate = config.mGTD.getOptTxt('tickleractivatehour') || defaultHourToActivate;
var nowTime = new Date();
nowTime.setHours(nowTime.getHours() - hourToActivate); // i'm confused because of UTC versus local. I think mgtd_date is UTC. But has hh:mm:ss is 00:00:00 in local time
// a tickler without a date is active now. so please add a date to your ticklers. thanks Arkady Grudzinsky
return (!this.fields.mgtd_date || nowTime.convertToYYYYMMDDHHMM() >= this.fields.mgtd_date );
},
// Contributed by Michael Scherer
ticklerWillBeActiveWithin: function(numDays) {
// Ignore ticklers without date
if (!this.fields.mgtd_date)
return false;
var nowTime = new Date();
// Respect user settings (see tickerIsActive())
var defaultHourToActivate = 5; // fixme put elsewhere
var hourToActivate = config.mGTD.getOptTxt('tickleractivatehour') || defaultHourToActivate;
if (nowTime.getHours() < hourToActivate) {
// Too early in the morning, go back one day.
nowTime.setDate(nowTime.getDate() - 1);
}
// Start tomorrow
startTime = new Date(nowTime.getFullYear(), nowTime.getMonth(), nowTime.getDate() + 1);
// End in numDays days
endTime = new Date(nowTime.getFullYear(), nowTime.getMonth(), nowTime.getDate() + 1 + numDays);
return (startTime.convertToYYYYMMDDHHMM() <= this.fields.mgtd_date && endTime.convertToYYYYMMDDHHMM() > this.fields.mgtd_date);
}
});
merge(config.macros,{
ticklerAlert: {
handler: function (place,macroName,params,wikifier,paramString,tiddler) {
var realmFilter = '';
if (!config.mGTD.getOptChk('AlertsIgnoreRealm'))
realmFilter = ' && tiddler.tags.containsAny(config.macros.mgtdList.getActiveRealms())';
var theList = fastTagged('Tickler').
filterByTagExpr('!Actioned').
filterByEval('tiddler.ticklerIsActive()'+realmFilter);
if (theList.length > 0) {
var blinker = createTiddlyElement(place,'blink');
wikify('{{ticklerAlert{[[*ticklers*|Ticklers Requiring Action]]}}}',blinker,null,tiddler);
}
}
},
mgtdList: {
getActiveRealms: function() {
return store.fetchTiddler("MgtdSettings").getByIndex("Realm");
},
noActiveRealmMessage: function() {
// this doesn't work like it ought to?????
if (this.getActiveRealms().length == 0) {
//clearMessage();
displayMessage("Error: No active realms. Please activate at least one realm.");
}
},
getRealm: function(tiddlerTitle) {
// if we're in a project inherit the realm from the project
var inTiddler = store.fetchTiddler(tiddlerTitle);
if (inTiddler && inTiddler.tags.contains('Project')) {
// get the realm from the project
return inTiddler.getByIndex('Realm');
}
// otherwise use the active realm
var active = config.macros.mgtdList.getActiveRealms();
if (active.length == 1) {
return active[0];
}
else if (active.length == 0) {
var fudge = fastTagged('Realm')[0].title; // this is a little bit random but they should be seeing the warning by now and fixing it
return fudge;
}
else {
// if there's more than one active realm use a slice to get the realm priority and choose the highest one
// TODO, make this prettier
var toBeat = "zzzzzzz";
var soFar = active[0];
for (var i=0;i<active.length;i++) {
var pri = store.getTiddlerSlice(active[i],"priority");
if (pri && pri < toBeat) {
toBeat = pri;
soFar = active[i];
}
}
return soFar;
}
},
getNewButton: function(tags,extraTags) {
if (typeof tags != 'string')
tags = String.encodeTiddlyLinkList(tags);
return '<<newSavedTiddler label:+ tag:"'+tags+'">>'; // newSavedTiddler wants tags in one param?
},
getNewButton: function(tags,extraTags) {
if (typeof tags != 'string')
tags = String.encodeTiddlyLinkList(tags);
return '<<newSavedTiddler prompt:"Enter name for new %1:" tooltip:"Create a new %1" label:"+" tag:"%0">>'.format([
tags, // newSavedTiddler wants tags in one param?
tags.readBracketedList()[0] // just show first tag in prompt and tooltip. it's the important one
]);
},
handler: function (place,macroName,params,wikifier,paramString,tiddler) {
this.noActiveRealmMessage();
var pp = paramString.parseParams("tags",null,true);
// title of the list
var title = getParam(pp,"title","");
// local means only look at tiddlers tagged with this tiddler
// global means look at every tiddler
var tagMode = getParam(pp,"mode","local");
// optional. ignored unless mode global. specify for speed gains
var startTag = getParam(pp,"startTag");
// eg, "Next && !Done"
var tagExpr = getParam(pp,"tags","");
// additional filter. gets eval'ed
var whereExpr = getParam(pp,"where","");
// group by another tag
var groupBy = getParam(pp,"group","");
// group by count only mode
var groupCountOnly = getParam(pp,"groupCountOnly","");
// filter the groups by tag expr
var gTagExpr = getParam(pp,"gTag","");
// or eval'ed expression
var gWhereExpr = getParam(pp,"gWhere","");
// how to render list items
var viewType = getParam(pp,"view","plain");
// how to render headings
var gViewType = getParam(pp,"gView",groupBy);
// if there are tiddlers who aren't grouped then give them this title
// mainly used to label future actions...
var leftoverTitle = getParam(pp,"leftoverTitle","No "+groupBy);
// if set to "yes" then we ignore the realm and show everthing
var ignoreRealm = getParam(pp, "ignoreRealm","");
// sort items
var sortBy = getParam(pp,"sort","title");
// sort groups
var gSortBy = getParam(pp,"gSort","title");
// new button
var newButton = getParam(pp,"newButton",""); // not using
var newButtonTags = getParam(pp,"newButtonTags","");
// don't show empty list
var dontShowEmpty = getParam(pp,"dontShowEmpty","");
newButtonTags = newButtonTags.replace(/\[\(/g," [[").replace(/\)\]/g,"]] "); // change [(..)] to [[..]]
if (!startTag)
if (tagMode != "global")
startTag = tiddler.title;
var listRefreshContainer = createTiddlyElement(place,"div");
// TODO one big attribute?
listRefreshContainer.setAttribute("refresh","macro");
listRefreshContainer.setAttribute("macroName",macroName);
listRefreshContainer.setAttribute("title",title);
listRefreshContainer.setAttribute("startTag",startTag);
listRefreshContainer.setAttribute("tagMode",tagMode);
listRefreshContainer.setAttribute("tagExpr",tagExpr);
listRefreshContainer.setAttribute("groupBy",groupBy);
listRefreshContainer.setAttribute("groupCountOnly",groupCountOnly);
listRefreshContainer.setAttribute("gTagExpr",gTagExpr);
listRefreshContainer.setAttribute("whereExpr",whereExpr);
listRefreshContainer.setAttribute("gWhereExpr",gWhereExpr);
listRefreshContainer.setAttribute("sortBy",sortBy);
listRefreshContainer.setAttribute("gSortBy",gSortBy);
listRefreshContainer.setAttribute("viewType",viewType);
listRefreshContainer.setAttribute("gViewType",gViewType);
listRefreshContainer.setAttribute("ignoreRealm",ignoreRealm);
listRefreshContainer.setAttribute("leftoverTitle",leftoverTitle);
listRefreshContainer.setAttribute("newButton",newButton);
listRefreshContainer.setAttribute("newButtonTags",newButtonTags);
if (tiddler)
listRefreshContainer.setAttribute("tiddlerTitle",tiddler.title);
listRefreshContainer.setAttribute("dontShowEmpty",dontShowEmpty);
this.refresh(listRefreshContainer);
},
refresh: function(place) {
removeChildren(place);
var title = place.getAttribute("title");
var startTag = place.getAttribute("startTag");
var tagMode = place.getAttribute("tagMode");
var tagExpr = place.getAttribute("tagExpr");
var groupBy = place.getAttribute("groupBy");
var groupCountOnly = place.getAttribute("groupCountOnly");
var gTagExpr = place.getAttribute("gTagExpr");
var whereExpr = place.getAttribute("whereExpr");
var gWhereExpr = place.getAttribute("gWhereExpr");
var sortBy = place.getAttribute("sortBy");
var gSortBy = place.getAttribute("gSortBy");
var viewType = place.getAttribute("viewType");
var gViewType = place.getAttribute("gViewType");
var ignoreRealm = place.getAttribute("ignoreRealm");
var leftoverTitle = place.getAttribute("leftoverTitle");
var newButton = place.getAttribute("newButton");
var newButtonTags = place.getAttribute("newButtonTags");
var tiddlerTitle = place.getAttribute("tiddlerTitle");
var dontShowEmpty = place.getAttribute("dontShowEmpty");
var wikifyThis = "";
wikifyThis += "{{mgtdList{\n";
if (title != "")
wikifyThis += "!"+title
var nbTags;
if (newButtonTags != '') {
nbTags = [
newButtonTags, // the tags specified in the macro params
'[['+config.macros.mgtdList.getRealm(tiddlerTitle)+']]', // the realm. always want a realm
(tagMode=='global'?'':'[['+tiddlerTitle+']]') // if not global, then the add tiddler we're in, new here style
].join(' ');
var nbList = nbTags.readBracketedList();
var nbExtra = nbTags;
// also we want an area. another hack. darn you subprojects.. :)
if (nbList.contains('Project') && !nbList.containsAny(fastTagged('Area').toTitleList())) {
var foo = store.fetchTiddler(tiddlerTitle).getByIndex('Area');
if (foo.length > 0) {
nbExtra += ' [[' + foo[0] + ']]';
}
}
if (nbList.contains('Project') && !nbList.containsAny(fastTagged('ProjectStatus').toTitleList())) {
// stupid hack for subprojects list in project dashboards
// don't want to create a project with no status
// this is the hack:
nbExtra += ' Active';
}
// same hack thing for actions
if (nbList.contains('Action') && !nbList.containsAny(fastTagged('ActionStatus').toTitleList())) {
nbExtra += ' Next';
}
wikifyThis += this.getNewButton(nbExtra);
// but still use nbTags later on in group headings...
}
if (title != "" || newButton != "")
wikifyThis += "\n";
wikifyThis += "{{innerList{\n";
var checkForContent = wikifyThis;
var theList = [];
if (startTag && startTag != 'undefined'/* this sucks */) {
theList = fastTagged(startTag);
}
else {
// why so hard to get an array of all tiddlers?
store.forEachTiddler(function(t_title,t_tiddler) { theList.push(t_tiddler); });
}
if (tagExpr != "") theList = theList.filterByTagExpr(tagExpr);
if (whereExpr != "") theList = theList.filterByEval(whereExpr);
if (ignoreRealm != "yes") {
var activeRealms = config.macros.mgtdList.getActiveRealms();
theList = theList.select(function(t) {
var realm = t.getByIndex("Realm");
return (
realm.length == 0 || // so something with no realm shows up
realm.containsAny(activeRealms)
);
});
}
if (groupBy == "day") {
// experimental. changing a tag doesn't update modified so
// this isn't as useful
theList = theList.groupBy(function(t){return [t.modified.formatString('YYYY-0MM-0DD')];});
wikifyThis += theList.renderGrouped(viewType,gViewType,leftoverTitle);
}
else if (groupBy != "") {
theList = theList.groupByTag(groupBy,sortBy,gSortBy);
if (gTagExpr != "") theList = theList.filterGroupsByTagExpr(gTagExpr);
if (gWhereExpr != "") theList = theList.filterGroupsByEval(gWhereExpr);
wikifyThis += theList.renderGrouped(viewType,gViewType,leftoverTitle,null,groupCountOnly,nbTags);
}
else {
theList = theList.tiddlerSort(sortBy);
wikifyThis += theList.render(viewType);
}
var emptyList = false;
if (wikifyThis == checkForContent) {
emptyList = true;
wikifyThis += "{{none{none}}}";
}
wikifyThis += "}}}\n";
wikifyThis += "}}}\n";
if (!(dontShowEmpty == "yes" && emptyList))
wikify(wikifyThis,place,null,tiddler);
forceReflow(); // fixes rendering issues. (but probably doubles up rendering time??)
}
}
});
merge(config.macros,{
processInbox: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var shortHand = {
Action: {
'W': 'Waiting For',
'N': 'Next',
'F': 'Future',
'S': 'Starred'
},
Project: {
'A': 'Active',
'SM': 'Someday/Maybe',
'S': 'Starred'
}
};
wikify("Quick add projects and actions (See [[About Quick Add]] for more info):\n",place);
var pi = createTiddlyElement(place,"textarea",null,"piBox");
wikify("\n",place);
var a1 = createTiddlyCheckbox(place,"Open created projects",true,null);
a1.id = 'piShowProjects';
var a2 = createTiddlyCheckbox(place,"Open created actions",true,null);
a2.id = 'piShowActions';
wikify("\n",place);
var btn = createTiddlyButton(place,"quick add now","create these items",function(e) {
var lines = pi.value.split("\n");
var currentProject = "";
var displayThese = [];
for (var i=0;i<lines.length;i++) {
var fields_and_text = lines[i].trim().split(/[|;]{2}/); // anything after || is to become tiddler content
var fields = fields_and_text[0].trim().split(/[|;]/);
var tiddlerText = fields_and_text[1];
if (!fields[0] || fields[0].trim() == "") {
currentProject = "";
}
else {
var title = fields.shift();
//alert(title);
// add the realm
fields.push(config.macros.mgtdList.getRealm());
if (title.substr(0,1) != '.') {
//alert("project "+title);
currentProject = title;
if (document.getElementById('piShowProjects').checked)
displayThese.push(title);
fields.push("Project"); // make it a project
//fields.push("Active"); // make it active
if (!fields.containsAny(['SM','A']))
fields.push('A');
fields = fields.map(function(f) {
if (shortHand['Project'][f])
return shortHand['Project'][f];
else
return f;
});
if (store.tiddlerExists(title))
alert("Warning: '"+title+"' already exists, did not create");
else
store.saveTiddler(
title,title,
tiddlerText ? tiddlerText : "", // content
config.options.txtUserName,
new Date(),
fields, // tags
null // extra fields
);
}
else {
//alert("action "+title);
// default to next actions
if (!fields.containsAny(['N','F','W']))
fields.push('N');
fields = fields.map(function(f) {
if (shortHand['Action'][f])
return shortHand['Action'][f];
else
return f;
});
//alert("action "+title);
title = title.trim();
title = title.replace(/^\.+/,'');
// If the action is already existing
// let's presume that we want to create it as a unique action.
// Use some code from NewMeansNewPlugin.
if (config.macros.newTiddler.getName)
title = config.macros.newTiddler.getName(title);
if (document.getElementById('piShowActions').checked)
displayThese.push(title);
fields.push("Action"); // make it an action
if (currentProject.trim() != "")
fields.push(currentProject); // make it in this project
// these should be configurable
var automagicContexts = {
'Call':'call',
'Errand':'buy'
};
for (amc in automagicContexts) {
var checkExists = store.fetchTiddler(amc);
var startString = automagicContexts[amc];
if (title.substr(0,startString.length).toLowerCase() == startString && checkExists && checkExists.hasTag('Context')) {
fields.push(amc);
}
}
if (store.tiddlerExists(title))
alert("Warning: '"+title+" already exists, did not create");
else
store.saveTiddler(
title,title,
tiddlerText ? tiddlerText : "", // content
config.options.txtUserName,
new Date(),
fields, // tags
null // extra fields
);
}
}
}
for (var ii=0;ii<displayThese.length;ii++)
story.displayTiddler("bottom",displayThese[ii]);
displayMessage("Quick add items created");
// Clear the quick add text area and close the slider. (jQuery anyone?)
jQuery(pi).val('');
jQuery(pi).closest('.sliderPanel').hide();
return false;
}); // end of createTiddlyButton
// A button to clear the textarea
createTiddlyButton(place,"clear","Clear text",function(){ jQuery(pi).val(''); });
// A button to close the slider
createTiddlyButton(place,"close","Close Quick Add",function(){ jQuery(pi).closest('.sliderPanel').hide(); });
}
}
});
!!Options
Show tickler alerts regardless of realm settings.
<<toggleTag AlertsIgnoreRealm MgtdSettings>>
Actions can have multiple contexts.
<<toggleTag MultipleContexts MgtdSettings>>
Show full area name next to actions in action lists instead of just [A].
<<toggleTag FullAreaInActionLists MgtdSettings>>
Show full project name next to actions in action lists instead of just [P].
<<toggleTag FullProjectInActionLists MgtdSettings>>
Show full contact name next to actions in action lists instead of just [C].
<<toggleTag FullContactInActionLists MgtdSettings>>
Week should start on Monday in calendar popups.
<<toggleTag WeekStartsMonday MgtdSettings>>
Enter the date format for ticklers.
Tickler date format:<<mgtdEditField ticklerdateformat MgtdSettings>>
(see [[Date Formats|http://tiddlywiki.org/wiki/Date_Formats]])
Enter the date format for 'new journal'.
Journal date format:<<mgtdEditField newjournaldateformat MgtdSettings>>
(see [[Date Formats|http://tiddlywiki.org/wiki/Date_Formats]])
Hour that ticklers should become active on their tickler date. (0 = Midnight, 12 = Midday)
Tickler activate hour:<<mgtdEditField tickleractivatehour MgtdSettings>>
// requires MgtdIndexedTags for the fastTagged and getByIndex methods
// TODO make these usable without MgtdIndexedTags if it doesn't exist
merge(Tiddler.prototype,{
addTag: function(tag) {
store.setTiddlerTag(this.title,true,tag);
},
removeTag: function(tag) {
store.setTiddlerTag(this.title,false,tag);
},
setTagFromGroup: function(tagGroup,tag) {
var tagList = fastTagged(tagGroup);
// it goes slow if you don't do this
store.suspendNotifications();
// remove all the tags in the group
for (var i=0;i<tagList.length;i++)
this.removeTag(tagList[i].title);
// add the one selected
if (tag)
this.addTag(tag);
// touch the modified date so we can sort usefully
this.modified = new Date();
// resume notification and notify
store.resumeNotifications();
store.notify(this.title,true);
},
toggleTag: function(tag) {
store.setTiddlerTag(this.title,!this.hasTag(tag),tag);
// touch the modified date
this.modified = new Date();
},
hasTag: function(tag) {
return this.tags.contains(tag);
},
getParent: function(tag) {
return this.getByIndex(tag);
},
// experimental
getGrandParent: function(parentTag,grandParentTag) {
// eg tiddler.getGrandParent('Project','Area') ??
var result = [];
this.getByIndex(parentTag).each(function(parentTiddler){
// because can be multiple
store.fetchTiddler(parentTiddler).getByIndex(grandParentTag).each(function(grandParentTiddler){
result.push(grandParentTiddler);
});
});
return result;
},
// experimental. does this belong elsewhere?
actionInArea: function(area) {
//return this.getParent(area).contains(area) || this.getGrandParent('Project','Area').contains(area);
return this.getGrandParent('Project','Area').contains(area);
},
//-----------------------------------
// experimental. try action dependencies
actionsDependantOnThisAction: function() {
return fastTagged(this.title).filterByTagExpr("Action && (Future || Next) && !Done");
},
autoNextAnyWaitingActions: function() {
// XXX exactly what each am I using here?
// because it looks like this gets munged
// inside the each function. this makes me think
// i'm not using the each i think i'm using
// eek.
var thisTiddler = this;
this.actionsDependantOnThisAction().each(function(t){
if (thisTiddler.hasTag('Done')) {
if (t.actionCanBecomeNext()) {
// we still have to check because it might have multiple dependencies
if (!t.hasTag('Next')) {
t.setTagFromGroup('ActionStatus','Next');
displayMessage('Setting dependent action "' + t.title + '" to Next');
}
}
}
else {
// this is because what if we go in reverse, ie untick the done checkbox
// also why we need Future || Next in actionsDependantOnThisAction
// don't need to check anything because any one dependency is enough to trigger going back to Future
if (!t.hasTag('Future')) {
t.setTagFromGroup('ActionStatus','Future');
displayMessage('Setting dependent action "' + t.title + '" to Future');
}
}
});
},
actionGetDependencies: function() {
// an action with a parent action
// we will take to mean that the parent action
// must be done before this action
// can become a next action
return this.getParent('Action');
},
actionCanBecomeNext: function() {
var result = true;
this.actionGetDependencies().each(function(t){
if (!store.fetchTiddler(t).hasTag('Done')) {
// an action this action depends on is not done
result = false;
}
});
return result;
},
//-----------------------------------
hasParent: function(tag) {
return this.getParent(tag).length > 0;
},
realmMismatchWithParent: function(tag) {
var myRealm = this.getParent('Realm')[0];
if (!myRealm)
return true; // no realm, should be fixed..
var myParent = this.getParent(tag)[0];
if (!myParent)
return false; // nothing to be mismatched with
var parentTiddler = store.fetchTiddler(this.getParent(tag)[0]);
if (!parentTiddler)
return true; // doubt it would ever happen but...
parentRealm = parentTiddler.getParent('Realm')[0]; // we assume one realm only...
if (!parentRealm)
return true;
return parentRealm != myRealm;
}
});
merge(config.macros,{
singleToggleTag: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var pp = paramString.parseParams("tag",null,true);
if (!tiddler)
tiddler = store.getTiddler(getParam(pp,"title"));
var tag = getParam(pp,"tag");
var t = store.fetchTiddler(tag);
var title = getParam(pp,"title",tiddler.title);
var actOnTiddler = store.getTiddler(title);
var label = store.getTiddlerSlice(t.title,"button");
var labelOff = store.getTiddlerSlice(t.title,"buttonOff");
// dreadful hack
if (tag == "Starred")
label = config.mGTD.data.unicodeStar;
var autoClass = "button " + t.title.replace(/[\/ ]/g,'')
if (!label) label = t.title;
if (!labelOff) labelOff = label;
var curState = actOnTiddler.hasTag(tag);
var cl = createTiddlyButton(place, curState?label:labelOff, t.title, function(e) {
actOnTiddler.toggleTag(tag);
return false;
},
autoClass + " " + (curState ? "on" : "off")
);
}
},
groupOfSingleToggleTags: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var pp = paramString.parseParams("tag",null,true);
var useCheckbox = getParam(pp,"useCheckbox","");
if (!tiddler)
tiddler = store.getTiddler(getParam(pp,"title"));
var tag = getParam(pp,"tag");
var title = getParam(pp,"title",tiddler.title);
var refresh = getParam(pp,"refresh"); // stupid bit for pagetemplate hack
var includeNew = getParam(pp,"includeNew","yes"); // default on for the moment..
var actOnTiddler = store.getTiddler(title);
//// TODO: refactor. (This realm filtering is copy/pasted this from multiSelectTag...)
//the extra || condition below should take care of contexts now. so actually you can have realm specific contexts if you want
var thisRealm = tiddler.getParent('Realm')[0];
var filterRealm = "";
if (thisRealm && tag != "Realm") { // && tag != "Context") {
// only want to see things in my realm (or things that don't have a realm...)
filterRealm += "(tiddler.tags.contains('"+thisRealm.replace(/'/g,"\\'")+"') || !tiddler.hasParent('Realm'))";
}
var getValues = fastTagged(tag).filterByEval(filterRealm == '' ? 'true' : filterRealm).sort(function(a,b){
return a.sorterUtil(b,"orderSlice");
});
getValues.each(function(t) {
var label = store.getTiddlerSlice(t.title,"button");
var autoClass = "button " + t.title.replace(/[\/ ]/g,'')
if (!label)
label = t.title;
if (useCheckbox == "yes") {
// checkbox style toggle tags
wikify("<<toggleTag [["+t.title+"]] [["+tiddler.title+"]] ->>[["+label+"]] " ,place,null,tiddler);
}
else {
// button style toggle tags
var cl = createTiddlyButton(place, label, t.title, function(e) {
actOnTiddler.toggleTag(t.title);
if (refresh == "page")
refreshPageTemplate();
return false;
},
autoClass + " " + (actOnTiddler.getByIndex(tag).contains(t.title) ? "on" : "off")
);
}
});
if (includeNew) {
// add a button to create...
createTiddlyButton(place, "+", "New "+tag+"...", function(e) {
var newItemTitle = config.macros.multiSelectTag.createNewItem(tag);
if (newItemTitle)
actOnTiddler.addTag(newItemTitle);
if (tag == "Realm")
refreshPageTemplate();
return false;
},
tag == "Realm"?"button off":"button" // the class so it looks right in the top menu
);
}
}
},
multiToggleTag: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var pp = paramString.parseParams("tag",null,true);
if (!tiddler)
tiddler = store.getTiddler(getParam(pp,"title"));
var tag = getParam(pp,"tag");
var refresh = getParam(pp,"refresh"); // stupid bit for pagetemplate hack
var longVersion = getParam(pp,"longVersion");
var title = getParam(pp,"title",tiddler.title);
var actOnTiddler = store.getTiddler(title);
var getValues = fastTagged(tag).sort(function(a,b){
return a.sorterUtil(b,"orderSlice");
});
getValues.each(function(t) {
var label = store.getTiddlerSlice(t.title,longVersion?"buttonLong":"button");
var extraClass = store.getTiddlerSlice(t.title,"buttonClass");
var autoClass = (extraClass ? extraClass : "") + " button " + t.title.replace(/[\/ ]/g,'')
if (!label) label = t.title;
var cl = createTiddlyButton(place, label, t.title, function(e) {
actOnTiddler.setTagFromGroup(tag,t.title);
if (refresh == "page")
refreshPageTemplate();
return false;
},
autoClass + " " + (actOnTiddler.getByIndex(tag).contains(t.title) ? "on" : "off")
);
});
}
},
multiSelectTag: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var pp = paramString.parseParams("tag",null,true);
if (!tiddler)
tiddler = store.getTiddler(getParam(pp,"title"));
var tag = getParam(pp,"tag");
var refresh = getParam(pp,"refresh"); // stupid bit for pagetemplate hack
var allowNone = getParam(pp,"allowNone");
var includeNew = getParam(pp,"includeNew","yes"); // default on for the moment..
var title = getParam(pp,"title",tiddler.title);
var actOnTiddler = store.getTiddler(title);
var selectOptions = [];
if (allowNone)
selectOptions.push({name: null, caption:'-'});// TODO this doesn't work right?
if (includeNew)
selectOptions.push({name: '__new__', caption:'New '+tag+'...'});
var getValues = fastTagged(tag).sort(function(a,b){
return a.sorterUtil(b,"orderSlice");
});
// a few automagic filters should make life easier
var thisRealm = tiddler.getParent('Realm')[0];
var filterRealm = "";
var filterComplete = "";
//the extra || condition below should take care of contexts now. so actually you can have realm specific contexts if you want
if (thisRealm && tag != "Realm") { // && tag != "Context") {
// only want to see things in my realm (or things that don't have a realm...)
filterRealm += "(tiddler.tags.contains('"+thisRealm.replace(/'/g,"\\'")+"') || !tiddler.hasParent('Realm'))";
}
if (tag == "Project") {
// only want to see active projects
filterComplete += "!tiddler.tags.contains('Complete')";
}
// Big thanks to Kralik and whoever wrote this: http://tiddlywiki.org/wiki/MonkeyGTD/Customization_Guide/Waiting_Actions
if (tag == "Action") {
// only want to see active actions; actions only show other actions in same project (or no project)
if (tiddler.hasParent('Project')) {
// XXX slightly broken for actions with multiple projects. But i can live with it..
// note: getParent returns an array
filterComplete += "(!tiddler.tags.contains('Done') && tiddler.tags.contains('"+tiddler.getParent('Project')[0].replace(/'/g,"\\'")+"'))";
}
else {
filterComplete += "(!tiddler.tags.contains('Done') && !tiddler.hasParent('Project'))";
}
}
var filterExpr = "true";
if (filterRealm != "" && filterComplete != "") {
filterExpr = filterRealm + " && " + filterComplete;
}
else if (filterRealm != "") {
filterExpr = filterRealm;
}
else if (filterComplete != "") {
filterExpr = filterComplete;
}
// ...yuck
// exclude ourselves (needed now for action dependencies)
filterExpr = "((" + filterExpr + ") && (tiddler.title != '" + tiddler.title.replace(/'/g,"\\'") + "'))";
var currentVal = tiddler.getParent(tag)[0];
if (currentVal && currentVal != '') {
// prevent weirdness if the current value isn't in the list
// eg an action in a completed project
filterExpr = "(" + filterExpr + ") || tiddler.title == '" + currentVal.replace(/'/g,"\\'") + "'";
}
if (tag == "Project" && tiddler.hasTag('Project')) {
// special case: don't let a project be a subproject of itself
filterExpr = "(" + filterExpr + ") && tiddler.title != '" + tiddler.title.replace(/'/g,"\\'") + "'";
}
// okay now do the filtering
getValues = getValues.filterByEval(filterExpr);
getValues.each(function(t) {
var useTitle = store.getTiddlerSlice(t.title,"button");
if (!useTitle) useTitle = t.title;
if (useTitle.length > 50) useTitle = useTitle.substr(0,50) + "...";
selectOptions.push({name: t.title, caption:useTitle});
});
var dd = createTiddlyDropDown(place, function(e) {
var selectedItem = selectOptions[this.selectedIndex].name;
if (selectedItem == '__new__') {
// User is creating a new item on the fly via the dropdown
var realm = null;
if (tag != "Realm") {
// Keep from double tagging in silly ways. Don't want realms to have a realm...
if (actOnTiddler.hasParent('Realm')) {
realm = actOnTiddler.getParent('Realm')[0]; // getParent returns array. use first realm
}
else {
realm = config.macros.mgtdList.getRealm();
}
}
selectedItem = config.macros.multiSelectTag.createNewItem(tag, realm);
}
// if selectedItem is null this works to remove any
actOnTiddler.setTagFromGroup(tag,selectedItem);
// Once again, big thanks to Kralik and whoever wrote this: http://tiddlywiki.org/wiki/MonkeyGTD/Customization_Guide/Waiting_Actions
// automatically make dependent actions future
if (tag == "Action") {
if (selectedItem == null) {
actOnTiddler.setTagFromGroup("ActionStatus", "Next");
}
else {
actOnTiddler.setTagFromGroup("ActionStatus", "Future");
}
}
if (refresh == "page")
refreshPageTemplate();
return false;
},
selectOptions,
actOnTiddler.getByIndex(tag)[0]
);
},
// want to reuse this...
createNewItem: function(tag, realm) {
var selectedItem = prompt("Enter name for new "+tag+":","");
if (selectedItem) {
selectedItem = config.macros.newTiddler.getName(selectedItem); // from NewMeansNewPlugin
var tags = [];
tags.push(tag); // make it into the thing you want
if (realm) // make sure it's got a realm unless it IS a realm
tags.push(realm);
if (tag == "Project")
tags.push("Active"); // if it's a project then make it active...
if (tag == "Action")
tags.push("Next"); // if it's an action then make it next...
store.saveTiddler(selectedItem,selectedItem,"",config.options.txtUserName,new Date(),tags);
}
return selectedItem;
}
},
multiCheckboxTag: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var pp = paramString.parseParams("tag",null,true);
if (!tiddler)
tiddler = store.getTiddler(getParam(pp,"title"));
var tag = getParam(pp,"tag");
var title = getParam(pp,"title",tiddler.title);
var actOnTiddler = store.getTiddler(title);
var getValues = fastTagged(tag).sort(function(a,b){
return a.sorterUtil(b,"orderSlice");
});
var output = "";
getValues.each(function(t) {
output += "<<toggleTag [[%0]] [[%1]] [[%0]]>>".format([
t.title,
actOnTiddler.title
]);
});
wikify(output,place,null,tiddler);
}
},
// these don't really belong here but never mind..
convertToFromTickler: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
if (tiddler.tags.contains('Tickler')) {
createTiddlyButton(place, "make action", "make this tickler into a next action", function(e) {
store.suspendNotifications();
tiddler.removeTag("Tickler");
tiddler.addTag("Action");
tiddler.removeTag("Done");
tiddler.setTagFromGroup("ActionStatus","Next");
store.resumeNotifications();
store.notify(tiddler.title,true);
return false;
});
createTiddlyButton(place, "make project", "make this tickler into an active project", function(e) {
store.suspendNotifications();
tiddler.removeTag("Tickler");
tiddler.addTag("Project");
tiddler.removeTag("Complete");
tiddler.setTagFromGroup("ProjectStatus",'Active');
store.resumeNotifications();
store.notify(tiddler.title,true);
return false;
});
}
if (tiddler.tags.containsAny(['Action','Project'])) {
createTiddlyButton(place, "make tickler", "make this item into a tickler", function(e) {
store.suspendNotifications();
if (tiddler.hasTag("Project")) {
// a little trick. it makes any actions associated with this project disappear from action lists
// thanks to Jorge A. Ramos M.
tiddler.setTagFromGroup("ProjectStatus",'Someday/Maybe');
}
tiddler.removeTag("Action");
tiddler.removeTag("Project");
tiddler.addTag("Tickler");
if (!tiddler.tags.containsAny(['Daily','Weekly','Monthly','Yearly'])) {
// thanks Kyle Baker
tiddler.addTag("Once");
}
store.resumeNotifications();
store.notify(tiddler.title,true);
return false;
});
}
}
},
convertActionToSubProj: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
if (tiddler.tags.contains('Action')) {
createTiddlyButton(place, "make project", "make this action into a project", function(e) {
store.suspendNotifications();
tiddler.removeTag("Action");
tiddler.removeTag("Next");
tiddler.removeTag("Future");
tiddler.removeTag("Waiting For");
tiddler.removeTag("Done");
tiddler.addTag("Project");
tiddler.addTag("Active");
store.resumeNotifications();
store.notify(tiddler.title,true);
return false;
});
}
}
},
convertActionToReference: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
if (tiddler.tags.contains('Action')) {
createTiddlyButton(place, "make reference", "make this action into a reference item", function(e) {
store.suspendNotifications();
tiddler.removeTag("Action");
tiddler.removeTag("Next");
tiddler.removeTag("Future");
tiddler.removeTag("Waiting For");
tiddler.removeTag("Done");
tiddler.addTag("Reference");
store.resumeNotifications();
store.notify(tiddler.title,true);
return false;
});
}
}
},
linkToParent: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var label = params[1] ? params[1] : '>>';
var useTiddler = params[2] ? store.fetchTiddler(params[2]) : tiddler;
var links = useTiddler.getByIndex(params[0]);
var output = "";
for (var i=0;i<links.length;i++)
output += ( (i==0?'':' ') + "[[%1|%0]]".format([links[i], label == 'title' ? '['+links[i]+']' : label]) );
if (output != "")
wikify(output,place,null,useTiddler);
}
},
// doesn't belong here since it's not a tag thing..
deleteTiddler: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var tiddlerToDelete = params[0];
if (store.tiddlerExists(tiddlerToDelete)) {
createTiddlyButton(place, '\u00d7', 'Delete tiddler '+tiddlerToDelete, function(e) {
var deleteIt = true;
if (config.options.chkConfirmDelete)
deleteIt = confirm(config.commands.deleteTiddler.warning.format([tiddlerToDelete]));
if (deleteIt) {
story.closeTiddler(tiddlerToDelete);
store.removeTiddler(tiddlerToDelete);
}
return false;
},'deleteTiddlerButton');
}
}
},
// contributed by ByteDoc
showNotesIcon: {
imageData: "data:image/gif;base64,R0lGODlhDgAOAKU3AHJcM21cQnFhRYBkLXVlSHdoS3hpTH5sQXxtUYpvNMeKCcuRD9CZBdKbGuCbAM+iEtWkHtmmELiqgb+tgeSsPMCwgt6wLMOyhMa1hd22O+m2OM68iuK/QOy8UdHBjOzEKdfGk/XJKujJVPbNZP7RNezRdvTTZf3SbP/Zc/HejPXkfP/jfvfln//ogv7uiPjvsv/1j/v1x///mf//qv/72v//xP//zP///////////////////////////////////yH5BAEKAD8ALAAAAAAOAA4AAAZ6QJBw6PFsNheJEkSz1Z7QKAIUm1mv2BkC85J5v2CZ4cKCmc9omKGScrnfcFdhUmrZ7/hWQdJRrf6AgQQSGRwZFg8mgX+DIgwhHwwcKyiVlQISIxYRJCENlpaYJ5oLDg4WKCeWARKqJxoQEAoQFB22rAe5CQkDvb0AwEEAOw==",
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var useTiddler = params[0] ? store.fetchTiddler(params[0]) : tiddler;
if (useTiddler.text != "") {
var safeNoteContent = wikifyPlain(useTiddler.title).trim().replace(/[\[\]\|]/g,'');
var noteOutput = (safeNoteContent == "") ?
"{{showNotesIcon{[img[%0]]}}}".format([config.macros.showNotesIcon.imageData]) :
"{{showNotesIcon{[img[%1|%0]]}}}".format([config.macros.showNotesIcon.imageData,safeNoteContent]);
var output = (config.browser.isIE ? "(n)" : noteOutput); // because IE doesn't support data urls
wikify(output,place,null,useTiddler);
}
}
}
});
TiddlyWiki.prototype.setTiddlerTag_orig_SequencedActionPlugin_mgtd3 = TiddlyWiki.prototype.setTiddlerTag;
TiddlyWiki.prototype.setTiddlerTag = function(title,status,tag) {
// Thanks Carsten Thiele
var returnVal = this.setTiddlerTag_orig_SequencedActionPlugin_mgtd3(title,status,tag);
var tiddler = this.fetchTiddler(title);
if (tiddler && tag == 'Done' && tiddler.hasTag('Action')) { // not doing ticklers yet...
tiddler.autoNextAnyWaitingActions();
}
return returnVal;
}
setStylesheet(["",
".button.off {font-weight:bold;border-color:#eee;background:#fff;color:#ccc;margin:0px;font-size:100%}",
".button.on {font-weight:bold;border-color:#444;background:#888;color:#fff;margin:0px;font-size:100%}",
".button.tiny { font-size:75%; }",
// TODO move this css elsewhere
"#realmSelector .button.off {margin:0 0.5em;padding:0 1em;border:2px solid #aaa;background:#eee;color:#333;}", // actually reversed, ie off is "on"
"#realmSelector .button.on {margin:0 0.5em;padding:0 1em;border:2px solid #999;background:#999;color:#ccc;}", // actually reversed, ie off is "on"
// TODO put into styles instead of here?
// actions
".viewer .Next.button.on {border-color:#55c;background:#cfa;color:#4a4;}",
".viewer .WaitingFor.button.on {border-color:#b84;background:#fdb;color:#b84;}",
".viewer .Future.button.on {border-color:#48b;background:#bdf;color:#48b;}",
// projects
".viewer .Active.button.on {border-color:#55c;background:#cfa;color:#4a4;}",
".viewer .SomedayMaybe.button.on {border-color:#48b;background:#bdf;color:#48b;}",
// ticklers
".viewer .Enabled.button.on {border-color:#55c;background:#cfa;color:#4a4;}",
".viewer .Disabled.button.on {border-color:#b84;background:#fdb;color:#b84;}",
".viewer .Starred.button {padding:0;font-size:100%;}",
".viewer .Starred.button.on {border-color:#fff;background:#fff;color:#f80;}",
".viewer .Starred.button.off {border-color:#fff;background:#fff;color:#ddd;}",
""].join("\n"),"tTag");
//}}}
URL: http://mgsd.tiddlyspot.com/upgrade.html
// won't be overwritten by updates
// eg:
//// config.options.txtTheme = 'MonkeyGTDPrint3x5';
//{{{
merge(config.macros, {
eval: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
wikify(eval(paramString),place,null,tiddler);
}
}
});
//}}}
https://www.evernote.com/shard/s2/nl/117413/ef678259-ea8f-4bd9-8ed1-0ff92abd849d
Fix these manually. These have either no realm or a different realm to their parent.
{{cols2{
{{col{
<<mgtdList
title:'Action/Project mismatch'
startTag:Action
view:star
mode:global
ignoreRealm:yes
where:"tiddler.realmMismatchWithParent('Project')"
group:Project
gView:bold
>>
}}}
{{col{
<<mgtdList
title:'Projects/Area mismatch'
startTag:Project
view:star
mode:global
ignoreRealm:yes
where:"tiddler.realmMismatchWithParent('Area')"
group:Area
gView:bold
>>
<<mgtdList
title:'Subproject/parent project mismatch'
startTag:Project
view:star
mode:global
ignoreRealm:yes
where:"tiddler.realmMismatchWithParent('Project')"
>>
}}}
}}}
https://www.evernote.com/shard/s2/nl/117413/b95e95b5-bffc-4915-8087-0f530427a6be/
/%
This is the contents of the help you get when you click the question mark button
%/
!Project
A [[Project|Projects Dashboard]] is made up of sub-projects, [[Action|Next and Waiting Actions]] items, and [[Reference Items]]. A project should have a defined set of tasks or actions (that may change) and when these tasks are done the project is done. If a project has no defined finish, consider calling it an [[Area]], and then make terminable projects in the area.
!Action
An [[Action|Next and Waiting Actions]] is a single task that can be completed at one point in time. If an action is more complex than this, considering making it a [[subproject|Subprojects]], or storing information in the action notes area. Using the [[CheckboxPlugin| http://www.tiddlytools.com/#CheckboxPlugin]] you can hid sub-actions inside an action.
!Tickler
A [[tickler|Tickler Dashboard]] is an [[Action|Next and Waiting Actions]] with a date attached. For example, if you need to call someone as part of a [[Project|Projects Dashboard]], that should be an action. But if you need to call someone on a specific day, then make it a [[tickler|Tickler Dashboard]] and MonkeyGTD will remind you on the day that you need to call them.
Example: The Health area contains a Dentist project with Actions Schedule Dentist, Go To Dentist and File Reimbursement. The latter two are Waiting while Schedule Dentist is Next. Once you call and schedule it, select the Go To Dentist Action, set it to Next, and then choose Make Tickler and set a date for the day of (or the day before) your appointment.
!View
No help yet for View
!Context
No help yet for Context
!Area
An [[Area]] is similar to a project, but it has no possible completion. Areas contain projects.
Example: The Health area might contain the project ''Run Marathon'', and the ''Household'' area might contain projects like ''Sell House'' and ''Buy House'' and ''Plant Garden'', each of which might have sub-projects.
!Realm
Realms are the top of the MonkeyGTD hierarchy. Realms contain Areas. Areas contain Projects. A Realm is a large-scale division of all the Areas, Projects, and Actions that might be placed into a GTD context.
!Reference
No help yet for Reference
!Action Dashboard
This Dashboard is the place where you can get an overview of your next actions.
!Action Dashboard by Project
This Dashboard is the place where you can get an overview of your next actions organised by Project. Note that when doing work you shouldn't be really be using this view. You should be focussed on context rather than project.
!Action Dashboard by Context
This Dashboard is the place where you can get an overview of your next actions organised by Context. This might be too cluttered if you have a lot of actions. If you know you are in a particular context consider just clicking the context to focus on that context.
!Next Actions
No help yet for Next Actions
!Next Actions by Context
No help yet for Next Actions by Context
!Next Actions by Project
No help yet for Next Actions by Project
!Projects Dashboard
No help yet for Projects Dashboard
!Projects Dashboard by Area
No help yet for Projects Dashboard by Area
!Next and Waiting Actions
No help yet for Next and Waiting Actions
!Next and Waiting Actions by Context
No help yet for Next and Waiting Actions by Context
!Next and Waiting Actions by Project
No help yet for Next and Waiting Actions by Project
!Done Actions
No help yet for Done Actions
!Active Projects With No Next Action
No help yet for Active Projects With No Next Action
!Quick Add
No help yet for Quick Add
!About Quick Add
No help yet for About Quick Add
!Tickler Dashboard
No help yet for Tickler Dashboard
!Ticklers Requiring Action
No help yet for Ticklers Requiring Action
!Reference Items
No help yet for Reference Items
!Starred Items
No help yet for Starred Items
|Name|MonkeyGTD Narrow|
|Description|MonkeyGTD Theme for Narrow Screens|
|PageTemplate|MonkeyGTDTheme##PageTemplate|
|StyleSheet|MonkeyGTDNarrow##StyleSheet|
|ViewTemplate|MonkeyGTDTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
!StyleSheet
/*{{{*/
[[MonkeyGTDTheme##StyleSheet]]
/* give a little less space for menu */
#sidebar { width: 16em; /* instead of 16em */ }
#displayArea { margin-right:15.7em; /* instead of 15.7em */ }
#sidebarTabs .tabContents { width:15em; /* instead of 15em */ }
.txtMGTDMain .tab {
font-size:80%!important;
}
.txtMGTDMain .tabContents {
font-size:90%;
}
[[StyleSheet]]
/*}}}*/
|Name|MonkeyGTD Print 3x5|
|Description|MonkeyGTD Theme for Printing 3x5 Cards|
|PageTemplate|MonkeyGTDTheme##PageTemplate|
|StyleSheet|MonkeyGTDPrint3x5##StyleSheet|
|ViewTemplate|MonkeyGTDTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
!StyleSheet
/*{{{*/
[[MonkeyGTDTheme##StyleSheet]]
[[MonkeyGTDTheme##Printing3x5Styles]]
[[StyleSheet]]
/*}}}*/
|Name|MonkeyGTD|
|Description|MonkeyGTD Theme|
|PageTemplate|MonkeyGTDTheme##PageTemplate|
|StyleSheet|MonkeyGTDTheme##StyleSheet|
|ViewTemplate|MonkeyGTDTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
!ViewTemplate
<!--{{{-->
<div macro="showWhen tiddler.tags.containsAny(config.mGTD.specialTags)">
[[MonkeyGTDTheme##ViewTemplateToolbar]]
<div class='titleContainer viewer'>[[TitleButtonsSelector]]</div>
<div macro="showWhenTaggedAny Reference View">
<!--- just make it look like a normal tiddler --->
<div class='viewer' macro='view text wikified'></div>
</div>
<div macro="else">
<div macro="showWhen tiddler.text != ''">
<div class='viewer'>Notes:</div>
<div class='viewer postityellow' macro='view text wikified'></div>
</div>
</div>
<div class='viewer'>[[DashboardSelector]]</div>
</div>
<div macro="hideWhen tiddler.tags.containsAny(config.mGTD.specialTags)">
<!--- use standard template for non gtd tiddlers --->
[[MptwTheme##ViewTemplate]]
</div>
<!--}}}-->
!ViewTemplateToolbar
<!--{{{-->
<!-- it's identical to Mptw at present except add Reference tag to new journal and new tiddler. will probably tweak it more later. -->
<div class='toolbar'>
<span macro="showWhenTagged systemConfig">
<span macro="toggleTag systemConfigDisable . '[[disable|systemConfigDisable]]'"></span>
</span>
<span macro="showWhenTagged systemTheme"><span macro="applyTheme"></span></span>
<span macro="showWhenTagged systemPalette"><span macro="applyPalette"></span></span>
<span macro="showWhen tiddler.tags.contains('css') || tiddler.title == 'StyleSheet'"><span macro="refreshAll"></span></span>
<span style="padding:1em;"></span>
<span macro='toolbar closeTiddler closeOthers +editTiddler deleteTiddler > fields syncing permalink references jump'></span>
<span macro='newHere label:"new here" tag:Reference'></span>
<span macro='newJournalHere {{config.mGTD.getOptTxt("newjournaldateformat")?config.mGTD.getOptTxt("newjournaldateformat"):"DD-mmm-YY 0hh:0mm"}} tag:Reference'></span>
<span macro="showWhenTagged Action"><span macro="newSavedTiddler title:'new dependent action' label:'new dependent action' tag:{{'Action Future [['+config.macros.mgtdList.getRealm()+']] [['+tiddler.getParent('Context')+']] [['+tiddler.getParent('Project')+']] [['+tiddler.title+']]'}}"></span></span>
</div>
<!--}}}-->
!Subtitle
<!--{{{-->
<span class='subtitle'>
Updated
<span macro='view modified date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>
(<span macro='message views.wikified.createdPrompt'></span>
<span macro='view created date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>)
</span>
<!--}}}-->
!PageTemplate
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<div style="float:right" id='searchBox' macro="search Search..."></div>
<div class='header2'>mGSD
<span style="font-size:75%;font-weight:normal;color:[[ColorPalette::PrimaryLight]];" macro="mgtdVersion"></span>
<span style="font-size:55%;font-weight:normal;color:[[ColorPalette::PrimaryLight]];">beta</span>
</div>
</div>
<div macro='gradient vert [[ColorPalette::PrimaryMid]] [[ColorPalette::PrimaryDark]]'>
<div style="float:right" id="toggleSideBar"><span macro="toggleSideBar"></span></div>
<div class='mtoolbar'>
<div>
<span class="label">REALM</span><span id='arealmSelector' macro="groupOfSingleToggleTags tag:Realm title:MgtdSettings refresh:page"></span>
<span id='ticklerAlert' refresh='content' tiddler='TicklerAlert' force="true"></span>
<span id='newButtons' refresh='content' tiddler='NewButtons'></span>
</div>
</div>
</div>
<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
<div id='sidebar'>
<div id='sidebarOptions'>
<span macro="saveChanges"></span>
<span macro="closeAll"></span>
<span macro="showWhen store.tiddlerExists('TspotSidebar')||store.isShadowTiddler('TspotSidebar')"><span refresh='content' tiddler='TspotSidebar'></span></span>
<span macro="showWhen store.tiddlerExists('MgtdSidebarExtra')"><span refresh='content' tiddler='MgtdSidebarExtra'></span></span>
</div>
<div id='sidebarTabs' refresh='content' force='true' tiddler='MGTDSidebar'></div>
</div>
<div id='displayArea'>
<div id='messageArea'></div>
<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->
!SidebarMenus
<!--{{{-->
<!--- not using --->
<div id='twsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('TW')">
<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>
<div id='sidebarTabs' refresh='content' force='true' tiddler='SideBarTabs'></div>
</div>
<div id='twsidebar' macro="hideWhen store.fetchTiddler('MgtdSettings').tags.contains('TW')">
<div id='sidebarOptions'>
<span macro="showWhen store.tiddlerExists('TspotSidebar')||store.isShadowTiddler('TspotSidebar')"><span refresh='content' tiddler='TspotSidebar'></span></span>
<span refresh='content' tiddler='CommonMenu'></span>
</div>
</div>
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Do Work')">
<div class="menu" refresh='content' tiddler='DoWorkMenu'></div>
</div>
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Review')">
<div class='menu' refresh='content' tiddler='ReviewMenu'></div>
</div>
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Process Inbox')">
<div class='menu' refresh='content' tiddler='ProcessInboxMenu'></div>
</div>
<!---
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Collect Items')">
<div class='menu' refresh='content' tiddler='CollectItemsMenu'></div>
</div>
--->
<div id='monkeygtdsidebar' macro="showWhen store.fetchTiddler('MgtdSettings').tags.contains('Config')">
<div class='menu' refresh='content' tiddler='ConfigMenu'></div>
</div>
<!--}}}-->
!Printing3x5Styles
/*{{{*/
@media print {
.cols3 .col {width: 100%; float:none;}
.cols2 .col {width: 100%; float:none;}
.titleContainer {text-align:center;}
/* LAYOUT ELEMENTS
========================================================== */
*
{
margin: 0;
padding: 0;
}
body {
background: #fff;
color: #000;
font-size: 6.2pt;
font-family: "Lucida Grande", "Bitstream Vera Sans", Helvetica,
Verdana, Arial, sans-serif;
}
img {
max-width: 2.5in;
max-height: 4.5in;
}
.tiddler {
margin: 0 0 2em 0;
border-top: 1px solid #000;
page-break-before: always;
}
.tiddler:first-child {
page-break-before: avoid;
}
p, blockquote, ul, li, ol, dt, dd, dl, table
{
margin: 0 0 .3em 0;
}
h1, h2, h3, h4, h5, h6
{
margin: .2em 0;
}
h1
{
font-size: 1.5em;
}
h2
{
font-size: 1.3em;
}
h3
{
font-size: 1.25em;
}
h4
{
font-size: 1.15em;
}
h5
{
font-size: 1.1em;
}
blockquote
{
margin: .6em;
padding-left: .6em;
border-left: 1px solid #ccc;
}
ul
{
list-style-type: circle;
}
li
{
margin: .1em 0 .1em 2em;
line-height: 1.4em;
}
table
{
border-collapse: collapse;
font-size: 1em;
}
hr {
border: none;
border-top: dotted 1px #777;
height: 1px;
color: #777;
margin: .6em 0;
}
}/* end @media print */
/*}}}*/
!StyleSheet
/*{{{*/
[[MptwTheme##StyleSheet]]
.header2 {
background:url(http://randomibis.com/images/monkeygtd/logo-trans.gif) no-repeat -15px 2px transparent;
padding:5px;
padding-left:80px;
color:white;
font-size:1.3em;
font-weight:bold;
}
#backstageShow { color:[[ColorPalette::PrimaryLight]] ! important; }
/* the png is superior due to alpha transparency. but IE can't do it */
/* html>body .header2 {background-image:url(http://randomibis.com/images/monkeygtd/logo-trans.png)} */
/* try this trick (also firefox only)... */
html>body .header2 {
background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFkAAABxBAMAAABM2hLHAAAAA3NCSVQICAjb4U/gAAAAMFBMVEX///////////////////////////////////////////////////////////////9Or7hAAAAAEHRSTlMAESIzRFVmd4iZqrvM3e7/dpUBFQAAAAlwSFlzAAGaAAABmgABJU9lCwAAABZ0RVh0Q3JlYXRpb24gVGltZQAwMy8xNS8wNszogUoAAAAldEVYdFNvZnR3YXJlAE1hY3JvbWVkaWEgRmlyZXdvcmtzIE1YIDIwMDSHdqzPAAAEIElEQVR4nK1Yz2sTURB+2SZtYm2o+OtS6x7Vg/UgSBVtD16k0Fbw5o/oH1CiHkSM2uKpIJL642wDevLQRlARRFMPejSKoCJIbD1oVXxYq7Umu+Pb3azNzpudpOB3eM2+fkzn+2be5k2FINDydhu1TeK0SELlRINkA/6kAeybjbHj4OFVeyPsDYtDHv1zI8mnPvjR/zTALuTbqmyoTzbk4ECVbNVnJ6z2dJW9WJ+d/C12+5k8rWvLwJyInPXIEmbNOuzilBAxj713AirHWLIBg0KsqOxS5IowzoF9g2MnbLW0LYhxgAX1qY9PvtPhdM0Z8sSl287z+hLMhtc0Na2W4efKx+pGdAK+hiZfyKulONazsKREJX+FJqtKChGRvZPTNZt9Ep6Q7LiTQbO92nFmCZskfDIJ9obfamktr0AtEi3Cl/06OzWjluSvPb9whpfAuqCxi47I1PfJx/gXkYPSvoecN2SvEDvlSzmI2Sr5EvQGd1ybS9YZi6rfOsxOOiJLL7FIDy2WGdxIfVfLEWsUR3HRhk+HK7JZAslWnR9Ak8fa8u01lcnkVPA5wZ1bQx4NbnQukDwPcRsZlZ5h2ElNZI5hh4gMQWEq+EwXpQoDUDfwInGo9DTJ8+B2fi1KOYadQn5FeZH54DMvErd8Jz5etUjglh/mRCaxSLaSbufXoAm477AiFllhyAb2aytXSfdFXYthrl07tUqOMWzcFFFeZC74vDyRdSqJNthKap3Ptis+3v9RpHa8t/5k2JrILNuumki2kstqV+xXHZEoFFtJ7XjzlcSh2EriUHwlcajWZYncyFVS82v4PcPGIiNsJbHImP3fRGp+se2qhcq+YNiaX6URho39ioIZTtb8ChG5y700an510SLfZRxiaxltZ99T5OY50Z8j/JIjFLs1L+J53a8YLTJpX1g5pkSiUCtxZh4ODEFhmxKJQnXNU+TIR7GvTITKPqfYLeryskr3S8vMQ5vt3nKxX1pmHgYycMe5uKNQmv0eMqJbmurijr7e94S26xolEk+N42S7RkbdH5pf8jjF7ij3Oz01jvyKATkrnTcflh2RKFRIJe+L+YwznZjB7R6ykuKBMG8RIrO0JekbMfXS6fmBt+nBJwGgTtgkbgo1+JR7CfqOU47Io3jbuA7WSY180flHhFZJhcgh/b8OTRW4rDqLnP83l+B1MEo0360EDmCRHtY9g3LgRdCxaApCpP+XVfK1E+r5QrmdEuljKDBejxqZdtFCiPSxUy6N101wTRDDUy1qx+tuORUq0o84AZZ/b14/os8VCBE1Xl/996QNTxr6wL7rJ68NTzpU8m9M7yMrsoq1j6DiJY+HJxJqvPZePHVE+ugD58WjDU9h2CRV8nF85Q5FrAhfDuMrdzhU8sDd3hHUEck1zhZiO1Gbv3NR7MzF6giHAAAAAElFTkSuQmCC)
}
.headerShadow, .headerForeground {
padding:0;
}
.mtoolbar { padding:0.1em; padding-top:0.5em;}
.mtoolbar .button { margin-left:0.5em; padding:0.2em 0.3em; margin:0.2em 0.3em; }
.mtoolbar .button.off {background-color:[[ColorPalette::TertiaryMid]]!important; color:black; font-weight:normal;border-color:[[ColorPalette::PrimaryDark]];}
.mtoolbar .button.on {background-color:[[ColorPalette::TertiaryLight]]; color:black; border-color:[[ColorPalette::PrimaryDark]];}
.mtoolbar .button {
-moz-border-radius-topleft: 0.5em;
-moz-border-radius-topright: 0.5em;
}
#newButtons { padding-left:3em; }
#newButtons br { display:none; }
#newButtons .button { background-color:transparent; color:white; border-color:transparent; }
.txtMGTDMain .tabContents {
font-size:120%;
}
.txtMGTDMore .tabContents {
font-size:90%;
}
.tabContents .sliderButton {
font-size:120%;
background-color:[[ColorPalette::TertiaryLight]];
}
.mtoolbar .label { font-size:80%; color:[[ColorPalette::PrimaryLight]]; padding:0.5em;}
#displayArea {
margin: 1em 15.7em 0em 1em; /* use the freed up space */
}
#sidebar, #sidebarOptions
width:18em;
}
#sidebarTabs {
width:100%;
}
#mainMenu { display:none; }
#sidebar .menu a {
font-size:140%;
}
#sidebar .menu ul {
padding-left:2em;
padding-top:0;
margin-top:0;
}
#sidebar .menu h1,
#sidebar .menu h2
{
color:[[ColorPalette::PrimaryDark]];
margin:0;
padding:0;
margin-top:0.25em;
}
#sidebar .menu h1 {
font-size:180%;
}
#sidebar .menu h2 {
font-size:140%;
margin-left:0.5em;
}
.viewer table.twocol,
.viewer table.threecol {
border-style:none ! important;
border-collapse:no-collapse;
width:100%;
padding:0; margin:0;
}
.viewer table.twocol td,
.viewer table.threecol td {
border-style:none ! important;
vertical-align:top;
padding-right:1em;
}
.viewer table.twocol tr,
.viewer table.threecol tr {
border-style:none ! important;
}
.viewer table.twocol td {
width:50%;
}
.viewer table.threecol td {
width:33%;
}
.mgtdList h1 {
border-bottom:1px solid #aaa;
color:#444;
font-size:110%;
margin:0;
padding:0;
}
.mgtdList h1 br {
display:none;
}
.mgtdList h1 .button {
border-color:transparent;
font-weight:bold;
font-size:110%;
}
.mgtdList h1 .button:hover {
border-color:#999;
}
.mgtdList h2 {
border-style:none!important;
font-size:100%;
margin:0; padding:0;
margin-top:0.7em;
margin-left:-0.2em;
color:#444;
}
.mgtdList h2 .button {
border-style:none!important;
}
.mgtdList {
padding:0;
padding-right:1em;
}
.mgtdList .innerList {
padding:0.5em 1em 0em 1em;
}
.tabContents .sliderPanel {
margin-left:2em;
}
.txtMGTDMain .mgtdList .innerList {
font-size:80%;
padding-left:0em;
}
.tabContents li {
margin-left:2em;
}
.mgtdList .plain { padding-left:1em; }
#sidebar .mgtdList .plain { padding-left:0em; }
#sidebar .tabContents .sliderPanel { margin-left:1em; }
#sidebar .sliderPanel .mgtdList .plain { padding-left:0em; }
#sidebar .mgtdList .noneHeading .tiddlyLink { font-weight:normal!important; }
/* TODO why not just make it all of them... */
.mgtdList .action .tiddlyLinkExisting,
.mgtdList .plain .tiddlyLinkExisting,
.mgtdList .tickler .tiddlyLinkExisting,
.mgtdList .project .tiddlyLinkExisting
{
font-weight: normal ! important;
}
/* TODO why not just make it all of them... */
.mgtdList .action .tiddlyLink,
.mgtdList .plain .tiddlyLink,
.mgtdList .tickler .tiddlyLink,
.mgtdList .project .tiddlyLink
{
font-weight: normal ! important;
}
.mgtdList .button {
font-weight: normal;
margin:1px;
}
body {
background: [[ColorPalette::TertiaryLight]];
}
.title { font-size:150%; color:black; }
#monkeygtdsidebar h1 {
font-size:120%; color:green;
}
.none { color:[[ColorPalette::TertiaryMid]]; font-size:90%; font-style:italic; }
.postityellow {
background-color:#ffa;
border:2px solid #dd8;
padding-left:1em;
padding-bottom:0.5em;
}
.postityellow h1,
.postityellow h2,
.postityellow h3,
.postityellow h4
{
border-style:none;
}
#sidebar .sliderButton { font-weight:bold; padding-left:0.25em; }
#sidebar .sliderPanel ul { margin-bottom:0px; }
#sidebar .sliderPanel li { font-weight:medium; font-size:90%; }
#sidebar .mgtdList .innerList .tiddlyLink {
font-size:120%;
}
.innerList h3 {
font-size:80%;
margin:0; padding:0;
}
#newButtons .sliderPanel {
background-color:[[ColorPalette::TertiaryMid]];
margin-top:4px;
padding:1em;
border-top:2px solid #444;
border-bottom:2px solid #444;
}
#newButtons .sliderPanel br {
display:inline;
}
#newButtons .sliderPanel .button {
font-weight:bold;
color:black
border:1px solid black;
background-color:#666;
}
.piBox {
width:95%;
height:8em;
}
.smaller { font-size: 85%; }
.scroll10 .innerList {
overflow:auto;
height:12em;
}
.dateBox {
/* TODO make prettier */
font-weight:medium; font-size:120%; margin:0.1em; background-color:#ffd;
border:1px solid #ccc;
background-color:#fff;
text-align:center;
width:10em;
}
.mgtdList .dateBox { font-weight:medium; font-size:100%; }
#ticklerAlert br { display:none; }
.ticklerAlert { padding-left:3em; }
.ticklerAlert .tiddlyLink { color:white; }
/* give a little more space for menu */
#sidebar { width: 21em; /* instead of 16em */ }
#displayArea { margin-right:20.7em; /* instead of 15.7em */ }
#sidebarTabs .tabContents { width:94%; /*16.5em; instead of 15em */ } /* this seems silly */
#messageArea .help { width:40em; font-size:90%; }
#searchBox {
position:absolute;
top: 2px;
right: 7em;
z-index:200;
/* make room for backstage link? */
}
#searchBox .button {
display:none;
}
.tabContents .button {
display:block;
}
.tabContents .li .button {
display:inline; /* hack to make for quickopentags in tabTags look right... */
}
.tabContents li .button {
display:inline; /* hack to make for quickopentags in tabTags look right... */
}
.txtMGTDMain .tab {
font-size:120%;
}
.projLink .tiddlyLinkExisting, .projLink {
font-weight:normal;
color:[[ColorPalette::TertiaryDark]];
}
.projLinkFull .tiddlyLinkExisting, .projLinkFull {
font-weight:normal;
color:[[ColorPalette::TertiaryDark]];
font-size:90%;
}
/* ============= new div based columns ================= */
.col {
float: left;
vertical-align:top;
}
.cols3, .cols2 {
overflow: auto; /* contains floats. tnx FND */
}
/* IE not doing these right :( */
/* .cols3>br, .col>br { display:none; } */
/* so try this instead. it's annoying and will mean you have trouble
with brs in non-mgtdlist content. .normal might help */
.cols2 br, .cols3 br { display:none; }
.mgtdList br, .normal { display:block!important; }
.col .mgtdList { margin-bottom:1.5em; } /* since we're no longer seeing the brs... */
.cols3 .col {
width: 33%;
}
.cols2 .col {
width: 49%; /* 50% makes IE put them under each other */
}
.clear {
clear: left;
}
/* ============= */
#toggleSideBar {
margin-top:0.5em;
margin-right:0.5em;
}
.button.HideSideBarButton {
color:[[ColorPalette::PrimaryLight]];
border-style:none;
font-weight:bold;
font-size:80%;
padding:0em 1em;
background-color:[[ColorPalette::PrimaryMid]];
-moz-border-radius: 0.5em;
}
/* applicable for any printing. (moved from the 3x5 section) */
@media print {
.viewer .tiddlyLink,
.mgtdList .tiddlyLink,
.tiddlyLink
{ color:black ! important; }
#sidebar, .mtoolbar, .header2, #toggleSideBar, #backstageArea,
#backstageButton, #searchBox, .subtitle, .button
{display: none !important;}
#displayArea {margin: 0;}
#contentWrapper .chkOptionInput {border:0; width:0.25cm;}
.titleContainer {border-bottom: 1px dotted #000;}
.scroll10 .innerList { height:auto; overflow:visible; }
}
.controls {
margin: auto;
margin:0; padding:0;
}
.controls tr, .controls td, .controls {
border-style:none!important;
border-collapse:no-collapse;
}
.controls {
clear:right;
padding:0.5em;
margin-top:1em;
padding-bottom:0.5em;
}
.controlstint {
background-color:#f0f0f0;
border:1px solid #ccc!important;
}
.toolbar .button {
border-style:none!important;
}
.controls .subtitle {
margin-left:0;
padding-left:0;
}
.controls .button {
background-color:#fff;
}
.controls .label {
color:#888; font-size:90%;
}
.controls .floatleft {
padding-right:1em;
float:left;
}
.controls .floatright {
padding-left:1em;
float:right;
}
.controls .clearleft { clear:left; }
.controls .clearright { clear:right; }
.controls .clearboth { clear:both; }
.controls .button.on {
background-color:#555; border-style:none!important;
}
.controlstint .button.Starred.off,
.controlstint .button.Starred.on
{ background-color:#f0f0f0; border-style:none!important;}
.unboldLinks .tiddlyLink {
font-weight:normal;
}
.smaller select { font-size:90%; }
.buttonsLikeLinks .button {
border-style:none!important;
background:transparent;
color:#008;
}
.buttonsLikeLinks .button:hover {
text-decoration:underline;
}
.deleteTiddlerButton {
color: #a66; font-weight:bold; margin-right:0.4em; margin-left:0.1em;
}
.tiny {
font-size:80%; /* lazy */
}
/* make the icon fit in a bit better */
.showNotesIcon img {
vertical-align:middle;
margin-right: 1px;
}
/* for user styles */
[[StyleSheet]]
/*}}}*/
order:5
button:month
buttonLong:monthly
Name: MptwBlack
Background: #000
Foreground: #fff
PrimaryPale: #333
PrimaryLight: #555
PrimaryMid: #888
PrimaryDark: #aaa
SecondaryPale: #111
SecondaryLight: #222
SecondaryMid: #555
SecondaryDark: #888
TertiaryPale: #222
TertiaryLight: #666
TertiaryMid: #888
TertiaryDark: #aaa
Error: #300
Name: MptwBlue
Background: #fff
Foreground: #000
PrimaryPale: #cdf
PrimaryLight: #57c
PrimaryMid: #114
PrimaryDark: #012
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
(function($){
merge(config.macros,{
mptwCollapse: {
handler: function(place,macroName,params) {
createTiddlyButton(place, params[0] == '+' ? '\u25AD' : '\u25AC', 'collapse/uncollapse', function(){
$(story.findContainingTiddler(place)).toggleClass('collapsed');
});
}
}
});
/* this doesn't work unless you have a modified ViewTempate */
config.shadowTiddlers["MptwCollapsePluginStyles"] = ""
+".collapsed .uncollapsedView { display:none; }"
+".collapsedView { display:none; }"
+".collapsed .collapsedView { display:block; }"
+".tiddler.collapsed { padding-bottom:1em; }"
+".tiddler.collapsed .title { font-size:100%; }"
;
store.addNotification("MptwCollapsePluginStyles",refreshStyles);
})(jQuery);
/***
|Name:|MptwConfigPlugin|
|Description:|Miscellaneous tweaks used by MPTW|
|Version:|1.0 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#MptwConfigPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#MptwConfigPlugin|
!!Note: instead of editing this you should put overrides in MptwUserConfigPlugin
***/
//{{{
var originalReadOnly = readOnly;
var originalShowBackstage = showBackstage;
config.options.chkHttpReadOnly = false; // means web visitors can experiment with your site by clicking edit
readOnly = false; // needed because the above doesn't work any more post 2.1 (??)
showBackstage = true; // show backstage for same reason
config.options.chkInsertTabs = true; // tab inserts a tab when editing a tiddler
config.views.wikified.defaultText = ""; // don't need message when a tiddler doesn't exist
config.views.editor.defaultText = ""; // don't need message when creating a new tiddler
config.options.chkSaveBackups = true; // do save backups
config.options.txtBackupFolder = 'twbackup'; // put backups in a backups folder
config.options.chkAutoSave = (window.location.protocol == "file:"); // do autosave if we're in local file
config.mptwVersion = "2.5.3";
config.macros.mptwVersion={handler:function(place){wikify(config.mptwVersion,place);}};
if (config.options.txtTheme == '')
config.options.txtTheme = 'MptwTheme';
// add to default GettingStarted
config.shadowTiddlers.GettingStarted += "\n\nSee also [[MPTW]].";
// add select theme and palette controls in default OptionsPanel
config.shadowTiddlers.OptionsPanel = config.shadowTiddlers.OptionsPanel.replace(/(\n\-\-\-\-\nAlso see \[\[AdvancedOptions\]\])/, "{{select{<<selectTheme>>\n<<selectPalette>>}}}$1");
// these are used by ViewTemplate
config.mptwDateFormat = 'DD/MM/YY';
config.mptwJournalFormat = 'Journal DD/MM/YY';
//}}}
Name: MptwGreen
Background: #fff
Foreground: #000
PrimaryPale: #9b9
PrimaryLight: #385
PrimaryMid: #031
PrimaryDark: #020
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
Name: MptwRed
Background: #fff
Foreground: #000
PrimaryPale: #eaa
PrimaryLight: #c55
PrimaryMid: #711
PrimaryDark: #500
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
|Name|MptwRounded|
|Description|Mptw Theme with some rounded corners (Firefox only)|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
|PageTemplate|MptwTheme##PageTemplate|
|StyleSheet|##StyleSheet|
!StyleSheet
/*{{{*/
[[MptwTheme##StyleSheet]]
.tiddler,
.sliderPanel,
.button,
.tiddlyLink,
.tabContents
{ -moz-border-radius: 1em; }
.tab {
-moz-border-radius-topleft: 0.5em;
-moz-border-radius-topright: 0.5em;
}
#topMenu {
-moz-border-radius-bottomleft: 2em;
-moz-border-radius-bottomright: 2em;
}
/*}}}*/
Name: MptwSmoke
Background: #fff
Foreground: #000
PrimaryPale: #aaa
PrimaryLight: #777
PrimaryMid: #111
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
|Name|MptwStandard|
|Description|Mptw Theme with the default TiddlyWiki PageLayout and Styles|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
Name: MptwTeal
Background: #fff
Foreground: #000
PrimaryPale: #B5D1DF
PrimaryLight: #618FA9
PrimaryMid: #1a3844
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #f8f8f8
TertiaryLight: #bbb
TertiaryMid: #999
TertiaryDark: #888
Error: #f88
|Name|MptwTheme|
|Description|Mptw Theme including custom PageLayout|
|PageTemplate|##PageTemplate|
|ViewTemplate|##ViewTemplate|
|EditTemplate|##EditTemplate|
|StyleSheet|##StyleSheet|
http://mptw.tiddlyspot.com/#MptwTheme ($Rev: 1829 $)
!PageTemplate
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<div class='headerShadow'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
<div class='headerForeground'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
</div>
<!-- horizontal MainMenu -->
<div id='topMenu' refresh='content' tiddler='MainMenu'></div>
<!-- original MainMenu menu -->
<!-- <div id='mainMenu' refresh='content' tiddler='MainMenu'></div> -->
<div id='sidebar'>
<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>
<div id='sidebarTabs' refresh='content' force='true' tiddler='SideBarTabs'></div>
</div>
<div id='displayArea'>
<div id='messageArea'></div>
<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->
!ViewTemplate
<!--{{{-->
<div class="uncollapsedView">
[[MptwTheme##ViewTemplateToolbar]]
<div class="tagglyTagged" macro="tags"></div>
<div class='titleContainer'>
<span class='title' macro='view title'></span>
<span macro="miniTag"></span>
</div>
<div class='subtitle'>
(updated <span macro='view modified date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>
by <span macro='view modifier link'></span>)
<!--
(<span macro='message views.wikified.createdPrompt'></span>
<span macro='view created date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>)
-->
</div>
<div macro="showWhen tiddler.tags.containsAny(['css','html','pre','systemConfig']) && !tiddler.text.match('{{'+'{')">
<div class='viewer'><pre macro='view text'></pre></div>
</div>
<div macro="else">
<div class='viewer' macro='view text wikified'></div>
</div>
<div class="tagglyTagging" macro="tagglyTagging"></div>
</div>
<div class="collapsedView">
<span class='toolbar'>
<span macro='toolbar closeTiddler'></span>
<span macro='mptwCollapse +'></span>
</span>
<span class='title' macro='view title'></span>
</div>
<!--}}}-->
!ViewTemplateToolbar
<!--{{{-->
<div class='toolbar'>
<span macro="showWhenTagged systemConfig">
<span macro="toggleTag systemConfigDisable . '[[disable|systemConfigDisable]]'"></span>
</span>
<span macro="showWhenTagged systemTheme"><span macro="applyTheme"></span></span>
<span macro="showWhenTagged systemPalette"><span macro="applyPalette"></span></span>
<span macro="showWhen tiddler.tags.contains('css') || tiddler.title == 'StyleSheet'"><span macro="refreshAll"></span></span>
<span style="padding:1em;"></span>
<span macro='toolbar closeTiddler closeOthers +editTiddler deleteTiddler > fields syncing permalink references jump'></span> <span macro='newHere label:"new here"'></span>
<span macro='newJournalHere {{config.mptwJournalFormat?config.mptwJournalFormat:"MM/0DD/YY"}}'></span>
<!--span macro='mptwCollapse -'></span-->
</div>
<!--}}}-->
!EditTemplate
<!--{{{-->
<div class="toolbar" macro="toolbar +saveTiddler saveCloseTiddler closeOthers -cancelTiddler cancelCloseTiddler deleteTiddler"></div>
<div class="title" macro="view title"></div>
<div class="editLabel">Title</div><div class="editor" macro="edit title"></div>
<div macro='annotations'></div>
<div class="editLabel">Content</div><div class="editor" macro="edit text"></div>
<div class="editLabel">Tags</div><div class="editor" macro="edit tags"></div>
<div class="editorFooter"><span macro="message views.editor.tagPrompt"></span><span macro="tagChooser"></span></div>
<!--}}}-->
!StyleSheet
/*{{{*/
/* a contrasting background so I can see where one tiddler ends and the other begins */
body {
background: [[ColorPalette::TertiaryLight]];
}
/* sexy colours and font for the header */
.headerForeground {
color: [[ColorPalette::PrimaryPale]];
}
.headerShadow, .headerShadow a {
color: [[ColorPalette::PrimaryMid]];
}
/* separate the top menu parts */
.headerForeground, .headerShadow {
padding: 1em 1em 0;
}
.headerForeground, .headerShadow {
font-family: 'Trebuchet MS', sans-serif;
font-weight:bold;
}
.headerForeground .siteSubtitle {
color: [[ColorPalette::PrimaryLight]];
}
.headerShadow .siteSubtitle {
color: [[ColorPalette::PrimaryMid]];
}
/* make shadow go and down right instead of up and left */
.headerShadow {
left: 1px;
top: 1px;
}
/* prefer monospace for editing */
.editor textarea, .editor input {
font-family: 'Consolas', monospace;
background-color:[[ColorPalette::TertiaryPale]];
}
/* sexy tiddler titles */
.title {
font-size: 250%;
color: [[ColorPalette::PrimaryLight]];
font-family: 'Trebuchet MS', sans-serif;
}
/* more subtle tiddler subtitle */
.subtitle {
padding:0px;
margin:0px;
padding-left:1em;
font-size: 90%;
color: [[ColorPalette::TertiaryMid]];
}
.subtitle .tiddlyLink {
color: [[ColorPalette::TertiaryMid]];
}
/* a little bit of extra whitespace */
.viewer {
padding-bottom:3px;
}
/* don't want any background color for headings */
h1,h2,h3,h4,h5,h6 {
background-color: transparent;
color: [[ColorPalette::Foreground]];
}
/* give tiddlers 3d style border and explicit background */
.tiddler {
background: [[ColorPalette::Background]];
border-right: 2px [[ColorPalette::TertiaryMid]] solid;
border-bottom: 2px [[ColorPalette::TertiaryMid]] solid;
margin-bottom: 1em;
padding:1em 2em 2em 1.5em;
}
/* make options slider look nicer */
#sidebarOptions .sliderPanel {
border:solid 1px [[ColorPalette::PrimaryLight]];
}
/* the borders look wrong with the body background */
#sidebar .button {
border-style: none;
}
/* this means you can put line breaks in SidebarOptions for readability */
#sidebarOptions br {
display:none;
}
/* undo the above in OptionsPanel */
#sidebarOptions .sliderPanel br {
display:inline;
}
/* horizontal main menu stuff */
#displayArea {
margin: 1em 15.7em 0em 1em; /* use the freed up space */
}
#topMenu br {
display: none;
}
#topMenu {
background: [[ColorPalette::PrimaryMid]];
color:[[ColorPalette::PrimaryPale]];
}
#topMenu {
padding:2px;
}
#topMenu .button, #topMenu .tiddlyLink, #topMenu a {
margin-left: 0.5em;
margin-right: 0.5em;
padding-left: 3px;
padding-right: 3px;
color: [[ColorPalette::PrimaryPale]];
font-size: 115%;
}
#topMenu .button:hover, #topMenu .tiddlyLink:hover {
background: [[ColorPalette::PrimaryDark]];
}
/* make 2.2 act like 2.1 with the invisible buttons */
.toolbar {
visibility:hidden;
}
.selected .toolbar {
visibility:visible;
}
/* experimental. this is a little borked in IE7 with the button
* borders but worth it I think for the extra screen realestate */
.toolbar { float:right; }
/* fix for TaggerPlugin. from sb56637. improved by FND */
.popup li .tagger a {
display:inline;
}
/* makes theme selector look a little better */
#sidebarOptions .sliderPanel .select .button {
padding:0.5em;
display:block;
}
#sidebarOptions .sliderPanel .select br {
display:none;
}
/* make it print a little cleaner */
@media print {
#topMenu {
display: none ! important;
}
/* not sure if we need all the importants */
.tiddler {
border-style: none ! important;
margin:0px ! important;
padding:0px ! important;
padding-bottom:2em ! important;
}
.tagglyTagging .button, .tagglyTagging .hidebutton {
display: none ! important;
}
.headerShadow {
visibility: hidden ! important;
}
.tagglyTagged .quickopentag, .tagged .quickopentag {
border-style: none ! important;
}
.quickopentag a.button, .miniTag {
display: none ! important;
}
}
/* get user styles specified in StyleSheet */
[[StyleSheet]]
/*}}}*/
|Name|MptwTrim|
|Description|Mptw Theme with a reduced header to increase useful space|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
|StyleSheet|MptwTheme##StyleSheet|
|PageTemplate|##PageTemplate|
!PageTemplate
<!--{{{-->
<!-- horizontal MainMenu -->
<div id='topMenu' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<span refresh='content' tiddler='SiteTitle' style="padding-left:1em;font-weight:bold;"></span>:
<span refresh='content' tiddler='MainMenu'></span>
</div>
<div id='sidebar'>
<div id='sidebarOptions'>
<div refresh='content' tiddler='SideBarOptions'></div>
<div style="margin-left:0.1em;"
macro='slider chkTabSliderPanel SideBarTabs {{"tabs \u00bb"}} "Show Timeline, All, Tags, etc"'></div>
</div>
</div>
<div id='displayArea'>
<div id='messageArea'></div>
<div id='tiddlerDisplay'></div>
</div>
/***
|Description:|A place to put your config tweaks so they aren't overwritten when you upgrade MPTW|
See http://www.tiddlywiki.org/wiki/Configuration_Options for other options you can set. In some cases where there are clashes with other plugins it might help to rename this to zzMptwUserConfigPlugin so it gets executed last.
***/
//{{{
// example: set your preferred date format
//config.mptwDateFormat = 'MM/0DD/YY';
//config.mptwJournalFormat = 'Journal MM/0DD/YY';
// example: set the theme you want to start with
//config.options.txtTheme = 'MptwRoundTheme';
// example: switch off autosave, switch on backups and set a backup folder
//config.options.chkSaveBackups = true;
//config.options.chkAutoSave = false;
//config.options.txtBackupFolder = 'backups';
// uncomment to disable 'new means new' functionality for the new journal macro
//config.newMeansNewForJournalsToo = false;
//}}}
<span id="gc-number-5" class="gc-cs-link" title="Call with Google Voice">888-821-0119</span>
https://www.evernote.com/shard/s2/nl/117413/10c89a7d-5983-4c6f-899d-a151886a07f3/
This requires that all future & current BPs use the same variable names across the board
/***
|Name|[[DatePlugin]]|
|Source|http://www.TiddlyTools.com/#DatePlugin|
|Documentation|http://www.TiddlyTools.com/#DatePluginInfo|
|Version|2.7.1|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|formatted dates plus popup menu with 'journal' link, changes and (optional) reminders|
This plugin provides a general approach to displaying formatted dates and/or links and popups that permit easy navigation and management of tiddlers based on their creation/modification dates.
!!!!!Documentation
>see [[DatePluginInfo]]
!!!!!Configuration
<<<
<<option chkDatePopupHideCreated>> omit 'created' section from date popups
<<option chkDatePopupHideChanged>> omit 'changed' section from date popups
<<option chkDatePopupHideTagged>> omit 'tagged' section from date popups
<<option chkDatePopupHideReminders>> omit 'reminders' section from date popups
<<option chkShowJulianDate>> display Julian day number (1-365) below current date
see [[DatePluginConfig]] for additional configuration settings, for use in calendar displays, including:
*date formats
*color-coded backgrounds
*annual fixed-date holidays
*weekends
<<<
!!!!!Revisions
<<<
2009.05.31 [2.7.1] in addRemindersToPopup(), 'new reminder....' command now uses {{{<<newTiddler>>}}} macro. Also, general code reduction/cleanup.
|please see [[DatePluginInfo]] for additional revision details|
2005.10.30 [0.9.0] pre-release
<<<
!!!!!Code
***/
//{{{
version.extensions.DatePlugin= {major: 2, minor: 7, revision: 1, date: new Date(2009,5,31)};
config.macros.date = {
format: 'YYYY.0MM.0DD', // default date display format
linkformat: 'YYYY.0MM.0DD', // 'dated tiddler' link format
linkedbg: '#babb1e', // 'babble'
todaybg: '#ffab1e', // 'fable'
weekendbg: '#c0c0c0', // 'cocoa'
holidaybg: '#ffaace', // 'face'
createdbg: '#bbeeff', // 'beef'
modifiedsbg: '#bbeeff', // 'beef'
remindersbg: '#c0ffee', // 'coffee'
weekend: [ 1,0,0,0,0,0,1 ], // [ day index values: sun=0, mon=1, tue=2, wed=3, thu=4, fri=5, sat=6 ],
holidays: [ '01/01', '07/04', '07/24', '11/24' ]
// NewYearsDay, IndependenceDay(US), Eric's Birthday (hooray!), Thanksgiving(US)
};
config.macros.date.handler = function(place,macroName,params)
{
// default: display current date
var now =new Date();
var date=now;
var mode='display';
if (params[0]&&['display','popup','link'].contains(params[0].toLowerCase()))
{ mode=params[0]; params.shift(); }
if (!params[0] || params[0]=='today')
{ params.shift(); }
else if (params[0]=='filedate')
{ date=new Date(document.lastModified); params.shift(); }
else if (params[0]=='tiddler')
{ date=store.getTiddler(story.findContainingTiddler(place).id.substr(7)).modified; params.shift(); }
else if (params[0].substr(0,8)=='tiddler:')
{ var t; if ((t=store.getTiddler(params[0].substr(8)))) date=t.modified; params.shift(); }
else {
var y = eval(params.shift().replace(/Y/ig,(now.getYear()<1900)?now.getYear()+1900:now.getYear()));
var m = eval(params.shift().replace(/M/ig,now.getMonth()+1));
var d = eval(params.shift().replace(/D/ig,now.getDate()+0));
date = new Date(y,m-1,d);
}
// date format with optional custom override
var format=this.format; if (params[0]) format=params.shift();
var linkformat=this.linkformat; if (params[0]) linkformat=params.shift();
showDate(place,date,mode,format,linkformat);
}
window.showDate=showDate;
function showDate(place,date,mode,format,linkformat,autostyle,weekend)
{
mode =mode||'display';
format =format||config.macros.date.format;
linkformat=linkformat||config.macros.date.linkformat;
// format the date output
var title=date.formatString(format);
var linkto=date.formatString(linkformat);
// just show the formatted output
if (mode=='display') { place.appendChild(document.createTextNode(title)); return; }
// link to a 'dated tiddler'
var link = createTiddlyLink(place, linkto, false);
link.appendChild(document.createTextNode(title));
link.title = linkto;
link.date = date;
link.format = format;
link.linkformat = linkformat;
// if using a popup menu, replace click handler for dated tiddler link
// with handler for popup and make link text non-italic (i.e., an 'existing link' look)
if (mode=='popup') {
link.onclick = onClickDatePopup;
link.style.fontStyle='normal';
}
// format the popup link to show what kind of info it contains (for use with calendar generators)
if (autostyle) setDateStyle(place,link,weekend);
}
//}}}
//{{{
// NOTE: This function provides default logic for setting the date style when displayed in a calendar
// To customize the date style logic, please see[[DatePluginConfig]]
function setDateStyle(place,link,weekend) {
// alias variable names for code readability
var date=link.date;
var fmt=link.linkformat;
var linkto=date.formatString(fmt);
var cmd=config.macros.date;
if ((weekend!==undefined?weekend:isWeekend(date))&&(cmd.weekendbg!=''))
{ place.style.background = cmd.weekendbg; }
if (hasModifieds(date)||hasCreateds(date)||hasTagged(date,fmt))
{ link.style.fontStyle='normal'; link.style.fontWeight='bold'; }
if (hasReminders(date))
{ link.style.textDecoration='underline'; }
if (isToday(date))
{ link.style.border='1px solid black'; }
if (isHoliday(date)&&(cmd.holidaybg!=''))
{ place.style.background = cmd.holidaybg; }
if (hasCreateds(date)&&(cmd.createdbg!=''))
{ place.style.background = cmd.createdbg; }
if (hasModifieds(date)&&(cmd.modifiedsbg!=''))
{ place.style.background = cmd.modifiedsbg; }
if ((hasTagged(date,fmt)||store.tiddlerExists(linkto))&&(cmd.linkedbg!=''))
{ place.style.background = cmd.linkedbg; }
if (hasReminders(date)&&(cmd.remindersbg!=''))
{ place.style.background = cmd.remindersbg; }
if (isToday(date)&&(cmd.todaybg!=''))
{ place.style.background = cmd.todaybg; }
if (config.options.chkShowJulianDate) { // optional display of Julian date numbers
var m=[0,31,59,90,120,151,181,212,243,273,304,334];
var d=date.getDate()+m[date.getMonth()];
var y=date.getFullYear();
if (date.getMonth()>1 && (y%4==0 && y%100!=0) || y%400==0)
d++; // after February in a leap year
wikify('@@font-size:80%;<br>'+d+'@@',place);
}
}
//}}}
//{{{
function isToday(date) // returns true if date is today
{ var now=new Date(); return ((now-date>=0) && (now-date<86400000)); }
function isWeekend(date) // returns true if date is a weekend
{ return (config.macros.date.weekend[date.getDay()]); }
function isHoliday(date) // returns true if date is a holiday
{
var longHoliday = date.formatString('0MM/0DD/YYYY');
var shortHoliday = date.formatString('0MM/0DD');
for(var i = 0; i < config.macros.date.holidays.length; i++) {
var holiday=config.macros.date.holidays[i];
if (holiday==longHoliday||holiday==shortHoliday) return true;
}
return false;
}
//}}}
//{{{
// Event handler for clicking on a day popup
function onClickDatePopup(e) { e=e||window.event;
var p=Popup.create(this); if (!p) return false;
// always show dated tiddler link (or just date, if readOnly) at the top...
if (!readOnly || store.tiddlerExists(this.date.formatString(this.linkformat)))
createTiddlyLink(createTiddlyElement(p,'li'),this.date.formatString(this.linkformat),true);
else
createTiddlyText(createTiddlyElement(p,'li'),this.date.formatString(this.linkformat));
if (!config.options.chkDatePopupHideCreated)
addCreatedsToPopup(p,this.date,this.format);
if (!config.options.chkDatePopupHideChanged)
addModifiedsToPopup(p,this.date,this.format);
if (!config.options.chkDatePopupHideTagged)
addTaggedToPopup(p,this.date,this.linkformat);
if (!config.options.chkDatePopupHideReminders)
addRemindersToPopup(p,this.date,this.linkformat);
Popup.show(); e.cancelBubble=true; if(e.stopPropagation)e.stopPropagation(); return false;
}
//}}}
//{{{
function indexCreateds() // build list of tiddlers, hash indexed by creation date
{
var createds= { };
var tiddlers = store.getTiddlers('title','excludeLists');
for (var t = 0; t < tiddlers.length; t++) {
var date = tiddlers[t].created.formatString('YYYY0MM0DD')
if (!createds[date])
createds[date]=new Array();
createds[date].push(tiddlers[t].title);
}
return createds;
}
function hasCreateds(date) // returns true if date has created tiddlers
{
if (!config.macros.date.createds) config.macros.date.createds=indexCreateds();
return (config.macros.date.createds[date.formatString('YYYY0MM0DD')]!=undefined);
}
function addCreatedsToPopup(p,when,format)
{
var force=(store.isDirty() && when.formatString('YYYY0MM0DD')==new Date().formatString('YYYY0MM0DD'));
if (force || !config.macros.date.createds) config.macros.date.createds=indexCreateds();
var indent=String.fromCharCode(160)+String.fromCharCode(160);
var createds = config.macros.date.createds[when.formatString('YYYY0MM0DD')];
if (createds) {
createds.sort();
var e=createTiddlyElement(p,'div',null,null,'created ('+createds.length+')');
for(var t=0; t<createds.length; t++) {
var link=createTiddlyLink(createTiddlyElement(p,'li'),createds[t],false);
link.appendChild(document.createTextNode(indent+createds[t]));
}
}
}
//}}}
//{{{
function indexModifieds() // build list of tiddlers, hash indexed by modification date
{
var modifieds= { };
var tiddlers = store.getTiddlers('title','excludeLists');
for (var t = 0; t < tiddlers.length; t++) {
var date = tiddlers[t].modified.formatString('YYYY0MM0DD')
if (!modifieds[date])
modifieds[date]=new Array();
modifieds[date].push(tiddlers[t].title);
}
return modifieds;
}
function hasModifieds(date) // returns true if date has modified tiddlers
{
if (!config.macros.date.modifieds) config.macros.date.modifieds = indexModifieds();
return (config.macros.date.modifieds[date.formatString('YYYY0MM0DD')]!=undefined);
}
function addModifiedsToPopup(p,when,format)
{
var date=when.formatString('YYYY0MM0DD');
var force=(store.isDirty() && date==new Date().formatString('YYYY0MM0DD'));
if (force || !config.macros.date.modifieds) config.macros.date.modifieds=indexModifieds();
var indent=String.fromCharCode(160)+String.fromCharCode(160);
var mods = config.macros.date.modifieds[date];
if (mods) {
// if a tiddler was created on this date, don't list it in the 'changed' section
if (config.macros.date.createds && config.macros.date.createds[date]) {
var temp=[];
for(var t=0; t<mods.length; t++)
if (!config.macros.date.createds[date].contains(mods[t]))
temp.push(mods[t]);
mods=temp;
}
mods.sort();
var e=createTiddlyElement(p,'div',null,null,'changed ('+mods.length+')');
for(var t=0; t<mods.length; t++) {
var link=createTiddlyLink(createTiddlyElement(p,'li'),mods[t],false);
link.appendChild(document.createTextNode(indent+mods[t]));
}
}
}
//}}}
//{{{
function hasTagged(date,format) // returns true if date is tagging other tiddlers
{
return store.getTaggedTiddlers(date.formatString(format)).length>0;
}
function addTaggedToPopup(p,when,format)
{
var indent=String.fromCharCode(160)+String.fromCharCode(160);
var tagged=store.getTaggedTiddlers(when.formatString(format));
if (tagged.length) var e=createTiddlyElement(p,'div',null,null,'tagged ('+tagged.length+')');
for(var t=0; t<tagged.length; t++) {
var link=createTiddlyLink(createTiddlyElement(p,'li'),tagged[t].title,false);
link.appendChild(document.createTextNode(indent+tagged[t].title));
}
}
//}}}
//{{{
function indexReminders(date,leadtime) // build list of tiddlers with reminders, hash indexed by reminder date
{
var reminders = { };
if(window.findTiddlersWithReminders!=undefined) { // reminder plugin is installed
var t = findTiddlersWithReminders(date, [0,leadtime], null, null, 1);
for(var i=0; i<t.length; i++) reminders[t[i].matchedDate]=true;
}
return reminders;
}
function hasReminders(date) // returns true if date has reminders
{
if (window.reminderCacheForCalendar)
return window.reminderCacheForCalendar[date]; // use calendar cache
if (!config.macros.date.reminders)
config.macros.date.reminders = indexReminders(date,90); // create a 90-day leadtime reminder cache
return (config.macros.date.reminders[date]);
}
function addRemindersToPopup(p,when,format)
{
if(window.findTiddlersWithReminders==undefined) return; // reminder plugin not installed
var indent = String.fromCharCode(160)+String.fromCharCode(160);
var reminders=findTiddlersWithReminders(when, [0,31],null,null,1);
createTiddlyElement(p,'div',null,null,'reminders ('+(reminders.length||'none')+')');
for(var t=0; t<reminders.length; t++) {
link = createTiddlyLink(createTiddlyElement(p,'li'),reminders[t].tiddler,false);
var diff=reminders[t].diff;
diff=(diff<1)?'Today':((diff==1)?'Tomorrow':diff+' days');
var txt=(reminders[t].params['title'])?reminders[t].params['title']:reminders[t].tiddler;
link.appendChild(document.createTextNode(indent+diff+' - '+txt));
}
if (readOnly) return; // readonly... omit 'new reminder...' command
var rem='\\<\\<reminder day:%0 month:%1 year:%2 title:"Enter a reminder title here"\\>\\>';
rem=rem.format([when.getDate(),when.getMonth()+1,when.getYear()+1900]);
var cmd="<<newTiddler label:[["+indent+"new reminder...]] prompt:[[add a reminder to '%0']]"
+" title:[[%0]] text:{{var t=store.getTiddlerText('%0','');t+(t.length?'\\n':'')+'%1'}} tag:%2>>";
wikify(cmd.format([when.formatString(format),rem,config.options.txtCalendarReminderTags||'']),
createTiddlyElement(p,'li'));
}
//}}}
<<newSavedTiddler title:'new Action' label:'+ action' tag:{{'Action Next [['+config.macros.mgtdList.getRealm()+']]'}}>>
<<newSavedTiddler title:'new Project' label:'+ project' tag:{{'Project Active [['+config.macros.mgtdList.getRealm()+']]'}}>>
/%<<newSavedTiddler title:'new Tickler' label:'+ tickler' tag:{{'Tickler Once [['+config.macros.mgtdList.getRealm()+']]'}}>>
%/<<calendarPopup '+ tickler' 'new Tickler'>>/% <-- experimental %/
<<newSavedTiddler title:'new Reference Item' label:'+ reference' tag:{{'Reference [['+config.macros.mgtdList.getRealm()+']]'}}>>
<slider quick add>
<<processInbox>>
</slider>
/***
|Name:|NewHerePlugin|
|Description:|Creates the new here and new journal macros|
|Version:|3.0 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#NewHerePlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
merge(config.macros, {
newHere: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
wikify("<<newTiddler "+paramString+" tag:[["+tiddler.title+"]]>>",place,null,tiddler);
}
},
newJournalHere: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
wikify("<<newJournal "+paramString+" tag:[["+tiddler.title+"]]>>",place,null,tiddler);
}
}
});
//}}}
/***
|Name:|NewMeansNewPlugin|
|Description:|If 'New Tiddler' already exists then create 'New Tiddler (1)' and so on|
|Version:|1.1.1 ($Rev: 2263 $)|
|Date:|$Date: 2007-06-13 04:22:32 +1000 (Wed, 13 Jun 2007) $|
|Source:|http://mptw.tiddlyspot.com/empty.html#NewMeansNewPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Note: I think this should be in the core
***/
//{{{
// change this or set config.newMeansNewForJournalsToo it in MptwUuserConfigPlugin
if (config.newMeansNewForJournalsToo == undefined) config.newMeansNewForJournalsToo = true;
String.prototype.getNextFreeName = function() {
numberRegExp = / \(([0-9]+)\)$/;
var match = numberRegExp.exec(this);
if (match) {
var num = parseInt(match[1]) + 1;
return this.replace(numberRegExp," ("+num+")");
}
else {
return this + " (1)";
}
}
config.macros.newTiddler.checkForUnsaved = function(newName) {
var r = false;
story.forEachTiddler(function(title,element) {
if (title == newName)
r = true;
});
return r;
}
config.macros.newTiddler.getName = function(newName) {
while (store.getTiddler(newName) || config.macros.newTiddler.checkForUnsaved(newName))
newName = newName.getNextFreeName();
return newName;
}
config.macros.newTiddler.onClickNewTiddler = function()
{
var title = this.getAttribute("newTitle");
if(this.getAttribute("isJournal") == "true") {
title = new Date().formatString(title.trim());
}
// ---- these three lines should be the only difference between this and the core onClickNewTiddler
if (config.newMeansNewForJournalsToo || this.getAttribute("isJournal") != "true")
title = config.macros.newTiddler.getName(title);
var params = this.getAttribute("params");
var tags = params ? params.split("|") : [];
var focus = this.getAttribute("newFocus");
var template = this.getAttribute("newTemplate");
var customFields = this.getAttribute("customFields");
if(!customFields && !store.isShadowTiddler(title))
customFields = String.encodeHashMap(config.defaultCustomFields);
story.displayTiddler(null,title,template,false,null,null);
var tiddlerElem = story.getTiddler(title);
if(customFields)
story.addCustomFields(tiddlerElem,customFields);
var text = this.getAttribute("newText");
if(typeof text == "string")
story.getTiddlerField(title,"text").value = text.format([title]);
for(var t=0;t<tags.length;t++)
story.setTiddlerTag(title,tags[t],+1);
story.focusTiddler(title,focus);
return false;
};
//}}}
config.macros.newSavedTiddler={};
config.macros.newSavedTiddler.handler = function(place,macroName,params,wikifier,paramString,tiddler) {
if (readOnly) {
return false;
}
var p = paramString.parseParams("anon",null,true,false,false);
var label = getParam(p,"label","NewSavedTiddler");
var tooltip = getParam(p,"tooltip","");
//
// if no tooltip specified, try prompt, title, label
//
if (!tooltip) {
var tPrompt = getParam(p,"prompt","");
var title = getParam(p,"title","");
var label = getParam(p,"label","");
if (tPrompt) {
tooltip = tPrompt;
}
else if (title) {
tooltip = 'Create a ' + title;
}
else if (label) {
tooltip = 'Create a ' + label;
}
else {
tooltip = 'Create a new saved tiddler';
}
}
var btn = createTiddlyButton(place,label,tooltip,this.onClick);
btn.params = paramString;
return false;
};
config.macros.newSavedTiddler.onClick = function(e) {
var p = this.params.parseParams("anon",null,true,false,false);
var titlePrompt = getParam(p,"prompt","");
//
// if no titlePrompt for the popup, try using the title or label fields
// to personalize the prompt
//
if (!titlePrompt) {
var titleT = getParam(p,"title","");
var labelT = getParam(p,"label","");
if (titleT) {
titlePrompt = 'Enter name for ' + titleT + ":";
}
else if (labelT) {
titlePrompt = 'Enter name for ' + labelT + ":";
}
else {
// default prompt
titlePrompt = 'Enter name for new tiddler:';
}
}
var title = prompt(titlePrompt,"");
if (title) {
if (typeof config.macros.newTiddler.getName == "function") {
title = config.macros.newTiddler.getName(title); // from NewMeansNewPlugin
}
var text = getParam(p,"text","");
var tags = getParam(p,"tag","");
var fields = getParam(p,"fields","").decodeHashMap();
tags = tags.replace(/\[\(/g,'[[');
tags = tags.replace(/\)\]/g,']]');
// Oveek: a fix for TiddlyWeb
// http://groups.google.com/group/TiddlyWikiDev/browse_thread/thread/edff49f9a9e9f47b/e02cb3c4ba88f819?pli=1
merge(fields, config.defaultCustomFields, true);
var tiddler = store.saveTiddler(title,title,text,config.options.txtUserName,new Date(),tags,fields);
autoSaveChanges(null,[tiddler]);
story.displayTiddler(this,title);
}
return false;
}
order:1
button:n
buttonLong:next
<<mgtdList title:'Next Actions' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
where:tiddler.hasActiveProject()
newButtonTags:'Action Next'
>>
<<mgtdList title:'Next Actions by Contact' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
group:Contact
gView:bold
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
<<mgtdList title:'Next Actions by Context' startTag:Action tags:'Next && !Done' view:ActionProj mode:global
group:Context
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
<<mgtdList startTag:Action tags:'Next && !Done' view:Action mode:global
group:Project
gView:bold
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
{{cols2{
{{col{
<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
}}}
{{col{
<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
newButtonTags:'Action [(Waiting For)]'
where:tiddler.hasActiveProject()
>>
}}}
}}}
{{cols2{
{{col{
<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
group:Contact
gView:bold
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
}}}
{{col{
<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
group:Contact
gView:bold
newButtonTags:'Action [(Waiting For)]'
where:tiddler.hasActiveProject()
>>
}}}
}}}
{{cols2{
{{col{
<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
group:Context
gView:Context
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
}}}
{{col{
<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
group:Contact
gView:bold
newButtonTags:'Action [(Waiting For)]'
where:tiddler.hasActiveProject()
>>
}}}
}}}
<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:ActionProj mode:global
group:Context
gView:Context
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:ActionProj mode:global
group:Context
gView:Context
newButtonTags:'Action [(Waiting For)]'
where:tiddler.hasActiveProject()
>>
{{cols2{
{{col{
<<mgtdList startTag:Action title:'Next' tags:'Next && !Done' view:Action mode:global
group:Project
gView:bold
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()
>>
}}}
{{col{
<<mgtdList startTag:Action title:'Waiting' tags:'[(Waiting For)] && !Done' view:Action mode:global
group:Project
gView:bold
where:tiddler.hasActiveProject()
newButtonTags:'Action [(Waiting For)]'
>>
}}}
}}}
order:1
button:none
buttonLong:one time
https://mail.google.com/mail/u/0/#inbox/139ad383939d22da
/***
|''Name:''|PasswordOptionPlugin|
|''Description:''|Extends TiddlyWiki options with non encrypted password option.|
|''Version:''|1.0.2|
|''Date:''|Apr 19, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#PasswordOptionPlugin|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0 (Beta 5)|
***/
//{{{
version.extensions.PasswordOptionPlugin = {
major: 1, minor: 0, revision: 2,
date: new Date("Apr 19, 2007"),
source: 'http://tiddlywiki.bidix.info/#PasswordOptionPlugin',
author: 'BidiX (BidiX (at) bidix (dot) info',
license: '[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D]]',
coreVersion: '2.2.0 (Beta 5)'
};
config.macros.option.passwordCheckboxLabel = "Save this password on this computer";
config.macros.option.passwordInputType = "password"; // password | text
setStylesheet(".pasOptionInput {width: 11em;}\n","passwordInputTypeStyle");
merge(config.macros.option.types, {
'pas': {
elementType: "input",
valueField: "value",
eventName: "onkeyup",
className: "pasOptionInput",
typeValue: config.macros.option.passwordInputType,
create: function(place,type,opt,className,desc) {
// password field
config.macros.option.genericCreate(place,'pas',opt,className,desc);
// checkbox linked with this password "save this password on this computer"
config.macros.option.genericCreate(place,'chk','chk'+opt,className,desc);
// text savePasswordCheckboxLabel
place.appendChild(document.createTextNode(config.macros.option.passwordCheckboxLabel));
},
onChange: config.macros.option.genericOnChange
}
});
merge(config.optionHandlers['chk'], {
get: function(name) {
// is there an option linked with this chk ?
var opt = name.substr(3);
if (config.options[opt])
saveOptionCookie(opt);
return config.options[name] ? "true" : "false";
}
});
merge(config.optionHandlers, {
'pas': {
get: function(name) {
if (config.options["chk"+name]) {
return encodeCookie(config.options[name].toString());
} else {
return "";
}
},
set: function(name,value) {config.options[name] = decodeCookie(value);}
}
});
// need to reload options to load passwordOptions
loadOptionsCookie();
/*
if (!config.options['pasPassword'])
config.options['pasPassword'] = '';
merge(config.optionsDesc,{
pasPassword: "Test password"
});
*/
//}}}
Build must occur during week of 7/8.
/***
|Name:|PrettyDatesPlugin|
|Description:|Provides a new date format ('pppp') that displays times such as '2 days ago'|
|Version:|1.0 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#PrettyDatesPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Notes
* If you want to you can rename this plugin. :) Some suggestions: LastUpdatedPlugin, RelativeDatesPlugin, SmartDatesPlugin, SexyDatesPlugin.
* Inspired by http://ejohn.org/files/pretty.js
***/
//{{{
Date.prototype.prettyDate = function() {
var diff = (((new Date()).getTime() - this.getTime()) / 1000);
var day_diff = Math.floor(diff / 86400);
if (isNaN(day_diff)) return "";
else if (diff < 0) return "in the future";
else if (diff < 60) return "just now";
else if (diff < 120) return "1 minute ago";
else if (diff < 3600) return Math.floor(diff/60) + " minutes ago";
else if (diff < 7200) return "1 hour ago";
else if (diff < 86400) return Math.floor(diff/3600) + " hours ago";
else if (day_diff == 1) return "Yesterday";
else if (day_diff < 7) return day_diff + " days ago";
else if (day_diff < 14) return "a week ago";
else if (day_diff < 31) return Math.ceil(day_diff/7) + " weeks ago";
else if (day_diff < 62) return "a month ago";
else if (day_diff < 365) return "about " + Math.ceil(day_diff/31) + " months ago";
else if (day_diff < 730) return "a year ago";
else return Math.ceil(day_diff/365) + " years ago";
}
Date.prototype.formatString_orig_mptw = Date.prototype.formatString;
Date.prototype.formatString = function(template) {
return this.formatString_orig_mptw(template).replace(/pppp/,this.prettyDate());
}
// for MPTW. otherwise edit your ViewTemplate as required.
// config.mptwDateFormat = 'pppp (DD/MM/YY)';
config.mptwDateFormat = 'pppp';
//}}}
[[Quick Add]]
''<<newSavedTiddler title:'new Next Action' label:'new next action' tag:{{'Action Next [['+config.macros.mgtdList.getRealm()+']]'}}>>/%/%
%/<<newSavedTiddler title:'new Waiting Action' label:'new waiting action' tag:{{'Action [(Waiting For)] [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Future Action' label:'new future action' tag:{{'Action Future [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Project' label:'new active project' tag:{{'Project Active [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Someday/Maybe Project' label:'new someday project' tag:{{'Project Someday/Maybe [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
<<newSavedTiddler title:'new Tickler' label:'new tickler' tag:{{'Tickler Once [['+config.macros.mgtdList.getRealm()+']]'}}>>
%/<<calendarPopup 'new tickler' 'new Tickler'>>/% <-- experimental
%/<<newSavedTiddler title:'new Reference Item' label:'new reference' tag:{{'Reference [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/
<<newSavedTiddler title:'new Contact' label:'new contact' tag:{{'Contact [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Context' label:'new context' tag:{{'Context [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Area' label:'new area' tag:{{'Area [['+config.macros.mgtdList.getRealm()+']]'}}>>/%
%/<<newSavedTiddler title:'new Realm' label:'new realm' tag:{{'Realm [['+config.macros.mgtdList.getRealm()+']]'}}>>''
!!Recent
<<mgtdList mode:global tags:'Project || Action' view:plain sort:-modified >>
{{tiny{
<slider Advanced>
[[modify menu|ProcessInboxMenu]]
[[GTDComponent]]
</slider>
}}}
{{cols2{
{{col{
<<mgtdList title:'Active Projects' startTag:Project tags:'Active && !Complete' view:ProjectArea mode:global
newButtonTags:'Project Active'
>>
}}}
{{col{
<<mgtdList title:'Someday/Maybe Projects' startTag:Project tags:'Someday/Maybe && !Complete' view:ProjectArea mode:global
newButtonTags:'Project Someday/Maybe'
>>
{{scroll10{
<<mgtdList title:'Completed Projects' startTag:Project tags:'Complete' view:ProjectComplete mode:global>>
}}}
}}}
}}}
{{cols2{
{{col{
<<mgtdList title:'Active Projects' startTag:Project tags:'Active && !Complete' view:Project mode:global
group:Area
gView:bold
newButtonTags:'Project Active'
>>
}}}
{{col{
<<mgtdList title:'Someday/Maybe Projects' startTag:Project tags:'Someday/Maybe && !Complete' view:Project mode:global
group:Area
gView:bold
newButtonTags:'Project Someday/Maybe'
>>
{{scroll10{
<<mgtdList title:'Completed Projects' startTag:Project tags:'Complete' view:ProjectComplete mode:global
group:Area
gView:bold
newButtonTags:'Project Active Complete'
>>
}}}
}}}
}}}
Kronos wants to install code on one of our servers (proprietary code). SI can interface with that server to SAP.
iPhone 5 and Otterbox case (Camo)
also purchased mophie for my iPhone
/***
|Name:|QuickOpenTagPlugin|
|Description:|Changes tag links to make it easier to open tags as tiddlers|
|Version:|3.0.1 ($Rev: 3861 $)|
|Date:|$Date: 2008-03-08 10:53:09 +1000 (Sat, 08 Mar 2008) $|
|Source:|http://mptw.tiddlyspot.com/#QuickOpenTagPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
config.quickOpenTag = {
dropdownChar: (document.all ? "\u25bc" : "\u25be"), // the little one doesn't work in IE?
createTagButton: function(place,tag,excludeTiddler) {
// little hack so we can do this: <<tag PrettyTagName|RealTagName>>
var splitTag = tag.split("|");
var pretty = tag;
if (splitTag.length == 2) {
tag = splitTag[1];
pretty = splitTag[0];
}
var sp = createTiddlyElement(place,"span",null,"quickopentag");
createTiddlyText(createTiddlyLink(sp,tag,false),pretty);
var theTag = createTiddlyButton(sp,config.quickOpenTag.dropdownChar,
config.views.wikified.tag.tooltip.format([tag]),onClickTag);
theTag.setAttribute("tag",tag);
if (excludeTiddler)
theTag.setAttribute("tiddler",excludeTiddler);
return(theTag);
},
miniTagHandler: function(place,macroName,params,wikifier,paramString,tiddler) {
var tagged = store.getTaggedTiddlers(tiddler.title);
if (tagged.length > 0) {
var theTag = createTiddlyButton(place,config.quickOpenTag.dropdownChar,
config.views.wikified.tag.tooltip.format([tiddler.title]),onClickTag);
theTag.setAttribute("tag",tiddler.title);
theTag.className = "miniTag";
}
},
allTagsHandler: function(place,macroName,params) {
var tags = store.getTags(params[0]);
var filter = params[1]; // new feature
var ul = createTiddlyElement(place,"ul");
if(tags.length == 0)
createTiddlyElement(ul,"li",null,"listTitle",this.noTags);
for(var t=0; t<tags.length; t++) {
var title = tags[t][0];
if (!filter || (title.match(new RegExp('^'+filter)))) {
var info = getTiddlyLinkInfo(title);
var theListItem =createTiddlyElement(ul,"li");
var theLink = createTiddlyLink(theListItem,tags[t][0],true);
var theCount = " (" + tags[t][1] + ")";
theLink.appendChild(document.createTextNode(theCount));
var theDropDownBtn = createTiddlyButton(theListItem," " +
config.quickOpenTag.dropdownChar,this.tooltip.format([tags[t][0]]),onClickTag);
theDropDownBtn.setAttribute("tag",tags[t][0]);
}
}
},
// todo fix these up a bit
styles: [
"/*{{{*/",
"/* created by QuickOpenTagPlugin */",
".tagglyTagged .quickopentag, .tagged .quickopentag ",
" { margin-right:1.2em; border:1px solid #eee; padding:2px; padding-right:0px; padding-left:1px; }",
".quickopentag .tiddlyLink { padding:2px; padding-left:3px; }",
".quickopentag a.button { padding:1px; padding-left:2px; padding-right:2px;}",
"/* extra specificity to make it work right */",
"#displayArea .viewer .quickopentag a.button, ",
"#displayArea .viewer .quickopentag a.tiddyLink, ",
"#mainMenu .quickopentag a.tiddyLink, ",
"#mainMenu .quickopentag a.tiddyLink ",
" { border:0px solid black; }",
"#displayArea .viewer .quickopentag a.button, ",
"#mainMenu .quickopentag a.button ",
" { margin-left:0px; padding-left:2px; }",
"#displayArea .viewer .quickopentag a.tiddlyLink, ",
"#mainMenu .quickopentag a.tiddlyLink ",
" { margin-right:0px; padding-right:0px; padding-left:0px; margin-left:0px; }",
"a.miniTag {font-size:150%;} ",
"#mainMenu .quickopentag a.button ",
" /* looks better in right justified main menus */",
" { margin-left:0px; padding-left:2px; margin-right:0px; padding-right:0px; }",
"#topMenu .quickopentag { padding:0px; margin:0px; border:0px; }",
"#topMenu .quickopentag .tiddlyLink { padding-right:1px; margin-right:0px; }",
"#topMenu .quickopentag .button { padding-left:1px; margin-left:0px; border:0px; }",
"/*}}}*/",
""].join("\n"),
init: function() {
// we fully replace these builtins. can't hijack them easily
window.createTagButton = this.createTagButton;
config.macros.allTags.handler = this.allTagsHandler;
config.macros.miniTag = { handler: this.miniTagHandler };
config.shadowTiddlers["QuickOpenTagStyles"] = this.styles;
store.addNotification("QuickOpenTagStyles",refreshStyles);
}
}
config.quickOpenTag.init();
//}}}
Completed. The next step is to conduct a complete end-to-end testing once the AS2 connection with Jacobson is setup.
TICKET #: 00390197 PRIORITY: 4
LOCATION: PLT99
Priya Parameswaran
PHONE: <span id="gc-number-6" class="gc-cs-link" title="Call with Google Voice">(816) 502-4000</span> EXT: ALT PHONE: <span id="gc-number-3" class="gc-cs-link" title="Call with Google Voice">(816) 556-5041</span>
CATEGORY: Vendor Escalation - Sterling
TICKET CREATOR: PARAMESP DATE/TIME LOGGED: 24/11/10 , 10:36:12
CALL DESCRIPTION:
Processing Step: X12 Translation
Process ID: 382065247
Time: 11/23/2010 19:47:31
ACTIVITY DESCRIPTION:
Rebel Oil 820
Known issue. TP is sending an extra space in the 820. See successful process ID: 382065250
https://ts1amr.accenture.com/sites/RecommendedLearning/Roadmaps/Home_Page.aspx
{{cols2{
{{col{
<<mgtdList title:'Reference Items For Active Projects' tag:Reference startTag:Reference view:plain mode:global
group:Project
gView:bold
newButtonTags:'Reference'
where:tiddler.hasActiveProject()
>>
}}}
{{col{
<<mgtdList title:'Other Reference Items' tag:Reference startTag:Reference view:plain mode:global
group:Project
gView:bold
newButtonTags:'Reference'
where:!tiddler.hasActiveProject()
>>
}}}
}}}
/***
|Name:|RenameTagsPlugin|
|Description:|Allows you to easily rename or delete tags across multiple tiddlers|
|Version:|3.0 ($Rev: 5501 $)|
|Date:|$Date: 2008-06-10 23:11:55 +1000 (Tue, 10 Jun 2008) $|
|Source:|http://mptw.tiddlyspot.com/#RenameTagsPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
Rename a tag and you will be prompted to rename it in all its tagged tiddlers.
***/
//{{{
config.renameTags = {
prompts: {
rename: "Rename the tag '%0' to '%1' in %2 tidder%3?",
remove: "Remove the tag '%0' from %1 tidder%2?"
},
removeTag: function(tag,tiddlers) {
store.suspendNotifications();
for (var i=0;i<tiddlers.length;i++) {
store.setTiddlerTag(tiddlers[i].title,false,tag);
}
store.resumeNotifications();
store.notifyAll();
},
renameTag: function(oldTag,newTag,tiddlers) {
store.suspendNotifications();
for (var i=0;i<tiddlers.length;i++) {
store.setTiddlerTag(tiddlers[i].title,false,oldTag); // remove old
store.setTiddlerTag(tiddlers[i].title,true,newTag); // add new
}
store.resumeNotifications();
store.notifyAll();
},
storeMethods: {
saveTiddler_orig_renameTags: TiddlyWiki.prototype.saveTiddler,
saveTiddler: function(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created,creator) {
if (title != newTitle) {
var tagged = this.getTaggedTiddlers(title);
if (tagged.length > 0) {
// then we are renaming a tag
if (confirm(config.renameTags.prompts.rename.format([title,newTitle,tagged.length,tagged.length>1?"s":""])))
config.renameTags.renameTag(title,newTitle,tagged);
if (!this.tiddlerExists(title) && newBody == "")
// dont create unwanted tiddler
return null;
}
}
return this.saveTiddler_orig_renameTags(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created,creator);
},
removeTiddler_orig_renameTags: TiddlyWiki.prototype.removeTiddler,
removeTiddler: function(title) {
var tagged = this.getTaggedTiddlers(title);
if (tagged.length > 0)
if (confirm(config.renameTags.prompts.remove.format([title,tagged.length,tagged.length>1?"s":""])))
config.renameTags.removeTag(title,tagged);
return this.removeTiddler_orig_renameTags(title);
}
},
init: function() {
merge(TiddlyWiki.prototype,this.storeMethods);
}
}
config.renameTags.init();
//}}}
https://www.evernote.com/shard/s2/nl/117413/f8c6d4f3-ed26-424f-a508-cbe3e6c4df8c/
https://www.evernote.com/shard/s2/nl/117413/2400d845-1089-4647-9131-cf594689b4a7
https://www.evernote.com/shard/s2/nl/117413/d490685e-1f5b-4b67-910f-1219c372711a
20130610 - Asked Ahmed to provide status update prior to this afternoon's meeting
20130610
Not Completed.
All except 1 minor issue that has do to with the product ID (EAN number Vs UPC Vs GTIN). I really need a 5min convo with Stefan to figure it out instead of all these emails back and forth. I sent him (and cc'd you) with an email explaining the issue.
20130610
Not Completed
Sawan, Ahmed
Wiating on feedback from the SAP team... sent a file to them on Wed of last week... no feedback yet. Ive followed up several times.
4:00 PM
Tuttle, David L.
ok
4:00 PM
Sawan, Ahmed
Ill work with the new guy... and see if they can assign it to him
4:00 PM
Tuttle, David L.
ok
4:01 PM
20130610 - Additional changes from Stefan today.
20130612 - Notified Amit that the file was waiting for approval from SAP team. Amit asked that we resend the file to him, and Byron resent today.
20130610 - Lean Order file completed weeks ago.
20130610 - No Update.
20130611 - Had issue with encashment file not processing on SAP. See separate note.
See Sharepoint.
https://hostessbrandsllc.sharepoint.com/sites/Teams%20Landing/IT/Integration/Shared%20Documents/Forms/AllItems.aspx?RootFolder=%2Fsites%2FTeams%20Landing%2FIT%2FIntegration%2FShared%20Documents%2FEDI%2FTrading%20Partners%2FAryzta%28Cloverhill%29&FolderCTID=0x012000D053D4F8C87A7540BC3354611DFCD0FD&View={AABF3AC2-383E-4F48-964E-2DE2EE590E14}
[[Projects Dashboard]]
[[Projects Dashboard by Area]]
[[Action Dashboard by Project]]
[[Active Projects With No Next Action]]
[[Someday Projects With No Tickler]]
[[Completed Projects]]
[[Done Actions]]
[[SomedayMaybe and Future]]
[[Delegated Tasks Dashboard]]
[[Cleanup]]
[[Mismatched Realms]]
[[Work Breakdown Projects]]
<slider+ Areas>
<<mgtdList startTag:Project tags:'Active && !Complete' groupCountOnly:yes group:Area gView:plain>>
</slider>
<slider All areas>
<<mgtdList startTag:Area>>
</slider>
<slider Contacts>
<<mgtdList startTag:Contact>>
</slider>
{{tiny{
<slider Advanced>
[[modify menu|ReviewMenu]]
[[GTDComponent]]
</slider>
}}}
https://www.evernote.com/shard/s2/nl/117413/bda29a7b-d5fa-4005-aa47-3a8e591afde8
Must specifically note in "Other" section:
Heat Access
SMS Access
4/8 - Byron working on this now.
• DB to SAP BAPI
• SAP must complete the BAPI program before this can be started
• Requested SAP make the program multi-threaded, however concerns on the DB tables SI uses to handle multiple records.
https://sms-ibc.accenture.com/itg/dashboard/app/portal/PageView.jsp
Susan stated, yesterday, that they have not yet begun the work on the set-up for HP3000 interfaces. She also stated that they were about to start up the work.
/***
|Name:|SaveCloseTiddlerPlugin|
|Description:|Provides two extra toolbar commands, saveCloseTiddler and cancelCloseTiddler|
|Version:|3.0 ($Rev: 5502 $)|
|Date:|$Date: 2008-06-10 23:31:39 +1000 (Tue, 10 Jun 2008) $|
|Source:|http://mptw.tiddlyspot.com/#SaveCloseTiddlerPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
To use these you must add them to the tool bar in your EditTemplate
***/
//{{{
merge(config.commands,{
saveCloseTiddler: {
text: 'done/close',
tooltip: 'Save changes to this tiddler and close it',
handler: function(ev,src,title) {
var closeTitle = title;
var newTitle = story.saveTiddler(title,ev.shiftKey);
if (newTitle)
closeTitle = newTitle;
return config.commands.closeTiddler.handler(ev,src,closeTitle);
}
},
cancelCloseTiddler: {
text: 'cancel/close',
tooltip: 'Undo changes to this tiddler and close it',
handler: function(ev,src,title) {
// the same as closeTiddler now actually
return config.commands.closeTiddler.handler(ev,src,title);
}
}
});
//}}}
https://www.evernote.com/shard/s2/nl/117413/dd663212-f552-4d15-8373-deb3019b25a0
https://www.evernote.com/shard/s2/nl/117413/dd663212-f552-4d15-8373-deb3019b25a0
/***
|Name:|SelectThemePlugin|
|Description:|Lets you easily switch theme and palette|
|Version:|1.0.1 ($Rev: 3646 $)|
|Date:|$Date: 2008-02-27 02:34:38 +1000 (Wed, 27 Feb 2008) $|
|Source:|http://mptw.tiddlyspot.com/#SelectThemePlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!Notes
* Borrows largely from ThemeSwitcherPlugin by Martin Budden http://www.martinswiki.com/#ThemeSwitcherPlugin
* Theme is cookie based. But set a default by setting config.options.txtTheme in MptwConfigPlugin (for example)
* Palette is not cookie based. It actually overwrites your ColorPalette tiddler when you select a palette, so beware.
!Usage
* {{{<<selectTheme>>}}} makes a dropdown selector
* {{{<<selectPalette>>}}} makes a dropdown selector
* {{{<<applyTheme>>}}} applies the current tiddler as a theme
* {{{<<applyPalette>>}}} applies the current tiddler as a palette
* {{{<<applyTheme TiddlerName>>}}} applies TiddlerName as a theme
* {{{<<applyPalette TiddlerName>>}}} applies TiddlerName as a palette
***/
//{{{
config.macros.selectTheme = {
label: {
selectTheme:"select theme",
selectPalette:"select palette"
},
prompt: {
selectTheme:"Select the current theme",
selectPalette:"Select the current palette"
},
tags: {
selectTheme:'systemTheme',
selectPalette:'systemPalette'
}
};
config.macros.selectTheme.handler = function(place,macroName)
{
var btn = createTiddlyButton(place,this.label[macroName],this.prompt[macroName],this.onClick);
// want to handle palettes and themes with same code. use mode attribute to distinguish
btn.setAttribute('mode',macroName);
};
config.macros.selectTheme.onClick = function(ev)
{
var e = ev ? ev : window.event;
var popup = Popup.create(this);
var mode = this.getAttribute('mode');
var tiddlers = store.getTaggedTiddlers(config.macros.selectTheme.tags[mode]);
// for default
if (mode == "selectPalette") {
var btn = createTiddlyButton(createTiddlyElement(popup,'li'),"(default)","default color palette",config.macros.selectTheme.onClickTheme);
btn.setAttribute('theme',"(default)");
btn.setAttribute('mode',mode);
}
for(var i=0; i<tiddlers.length; i++) {
var t = tiddlers[i].title;
var name = store.getTiddlerSlice(t,'Name');
var desc = store.getTiddlerSlice(t,'Description');
var btn = createTiddlyButton(createTiddlyElement(popup,'li'), name?name:t, desc?desc:config.macros.selectTheme.label['mode'], config.macros.selectTheme.onClickTheme);
btn.setAttribute('theme',t);
btn.setAttribute('mode',mode);
}
Popup.show();
return stopEvent(e);
};
config.macros.selectTheme.onClickTheme = function(ev)
{
var mode = this.getAttribute('mode');
var theme = this.getAttribute('theme');
if (mode == 'selectTheme')
story.switchTheme(theme);
else // selectPalette
config.macros.selectTheme.updatePalette(theme);
return false;
};
config.macros.selectTheme.updatePalette = function(title)
{
if (title != "") {
store.deleteTiddler("ColorPalette");
if (title != "(default)")
store.saveTiddler("ColorPalette","ColorPalette",store.getTiddlerText(title),
config.options.txtUserName,undefined,"");
refreshAll();
if(config.options.chkAutoSave)
saveChanges(true);
}
};
config.macros.applyTheme = {
label: "apply",
prompt: "apply this theme or palette" // i'm lazy
};
config.macros.applyTheme.handler = function(place,macroName,params,wikifier,paramString,tiddler) {
var useTiddler = params[0] ? params[0] : tiddler.title;
var btn = createTiddlyButton(place,this.label,this.prompt,config.macros.selectTheme.onClickTheme);
btn.setAttribute('theme',useTiddler);
btn.setAttribute('mode',macroName=="applyTheme"?"selectTheme":"selectPalette"); // a bit untidy here
}
config.macros.selectPalette = config.macros.selectTheme;
config.macros.applyPalette = config.macros.applyTheme;
config.macros.refreshAll = { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
createTiddlyButton(place,"refresh","refresh layout and styles",function() { refreshAll(); });
}};
//}}}
https://www.evernote.com/shard/s2/nl/117413/4bb9f689-237a-45c6-9a9e-caf5569853df
Destination will be IBM VAN
(You might want to these Someday/Maybe projects a tickler to remind you to review them at some point in the future)
<<mgtdList startTag:Project title:'Someday/Maybe projects without a tickler'
tags:'!Complete && Someday/Maybe' view:Project mode:global
where:!tiddler.hasTickler()
>>
order:2
button:s/m
buttonLong:someday/maybe
{{cols2{
{{col{
<<mgtdList title:'Someday/Maybe Projects' startTag:Project tags:'Someday/Maybe && !Complete' view:ProjectArea mode:global
newButtonTags:'Project Someday/Maybe'
>>
}}}
{{col{
<<mgtdList title:'Future Actions not in Projects' startTag:Action tags:'Future && !Done' view:Action mode:global
group:Context
gView:Context
newButtonTags:'Action Future'
where:!tiddler.hasParent('Project')
>>
}}}
}}}
http://teams/mis/am/ecommerce/speedway/Documents/Forms/AllItems.aspx?RootFolder=%2fmis%2fam%2fecommerce%2fspeedway%2fDocuments%2fSpeedway%20Minnesota&FolderCTID=&View=%7b0D625DA8%2d9007%2d4512%2d91C5%2dB957E923347A%7d
{{cols2{
{{col{
<<mgtdList title:'Starred Actions' startTag:Starred tags:'Action && !Done' view:ActionProj mode:global
group:ActionStatus
gView:bold
newButtonTags:'Starred Action'
>>
<<mgtdList title:'Starred Done Actions' startTag:Starred tags:'Done' view:DoneAction mode:global
newButtonTags:'Starred Action Done'
>>
}}}
{{col{
<<mgtdList title:'Starred Projects' startTag:Starred tags:'Project && !Complete' view:Project mode:global
group:ProjectStatus
gView:bold
newButtonTags:'Starred Project'
>>
<<mgtdList title:'Completed Projects' startTag:Starred tags:'Project && Complete' view:ProjectComplete mode:global
newButtonTags:'Starred Project Complete'
>>
<<mgtdList title:'Other Starred Items' startTag:Starred tags:'!Project && !Action' view:star mode:global
group:GTDComponent
gView:bold
newButtonTags:'Starred'
>>
}}}
}}}
<<mgtdList title:'Starred Next Actions by Context' startTag:Action tags:'Next && !Done && Starred' view:ActionProj mode:global
group:Context
newButtonTags:'Action Next Starred'
where:tiddler.hasActiveProject()
>>
table#datePickerTable td.datePickerNav {
cursor:pointer;
}
.datePickerDaysHeader td {
text-align:center;
background:#ABABAB;
font:100% Arial;
}
/*
.datePickerDayRow td {
width:18px;
height:18px;
}
*/
td#datePickerMNS, td.datePickerNav {
font-weight:bold;
}
table#datePickerTable {
position:absolute;
/* border-collapse:collapse; */
background:#FFFFFF;
border:1px solid #000;
display:none;
}
table#datePickerTable td {
padding: 3px;
}
td#datePickerMNS {
text-align: center;
}
tr.datePickerDayRow td {
background-color : #FFF;
cursor : pointer;
border : 1px solid #FFF;
text-align : center;
font-size:100%;
}
tr.datePickerDayRow td.defaultDate {
color : #000;
text-decoration : none;
}
tr.datePickerDayRow td.weekend {
color:#797!important;
}
tr.datePickerDowRow td {
color:#555;
text-align:center;
font-size:80%;
}
tr.datePickerDayRow td.emptyDate {
cursor:default;
}
tr.datePickerDayRow td.oldDate {
color : #ABABAB;
text-decoration : line-through;
}
tr.datePickerDayRow td.otherMonth {
color : #ccc!important;
}
tr.datePickerDayRow td.weekend.otherMonth {
color : #ddd!important;
}
tr.datePickerDayRow td.highlightedDate {
background-color : #fcc;
font-weight : bold;
border:1px solid #622;
}
tr.datePickerDayRow td.highlightedDate.tdover {
color : #000;
}
tr.datePickerDayRow td.todayDate {
font-weight : bold;
color : red;
}
table#datePickerTable tr.datePickerDayRow td.tdover {
background:#fc6;
}
<<tiddler SideBarOptions>>
<<tiddler SideBarTabs>>
<<tabs txtMoreTab "Tags" "All Tags" TabAllTags "Miss" "Missing tiddlers" TabMoreMissing "Orph" "Orphaned tiddlers" TabMoreOrphans "Shad" "Shadowed tiddlers" TabMoreShadowed>>
<<allTags excludeLists [a-z]>>
!Project
<!--{{{-->
<div class="cols3">
<div class="col">
[[TagDashboards##Ticklers Requiring Action]]
<div macro="mgtdList title:'Next Actions' tags:'Action && Next && !Done' view:Action
ignoreRealm:yes
group:Context
gView:Context
newButtonTags:'Action Next'
"></div>
<div macro="mgtdList title:'Waiting Actions by Person' tags:'Action && [(Waiting For)] && !Done' view:Action
ignoreRealm:yes
group:Contact
gView:bold
newButtonTags:'Action [(Waiting For)]'
"></div>
</div>
<div class="col">
<div macro="mgtdList title:'Active Subprojects' tags:'Project && !Complete' view:Project
ignoreRealm:yes
group:ProjectStatus
gView:bold
newButtonTags:'Project'
"></div>
<div macro="mgtdList title:'Completed Subprojects' tags:'Project && Complete' view:ProjectComplete
ignoreRealm:yes
newButtonTags:'Project Active Complete'
dontShowEmpty:yes
"></div>
<div macro="mgtdList title:'Future Actions' tags:'Action && Future && !Done' view:Action
ignoreRealm:yes
group:Context
gView:Context
newButtonTags:'Action Future'
"></div>
</div>
<div class="col">
[[TagDashboards##Upcoming Ticklers]]
<div macro="mgtdList title:'Reference Items' tags:'Reference' view:plain newButtonTags:'Reference'
ignoreRealm:yes
"></div>
<div macro="mgtdList title:'Done Actions' tags:'Action && Done' view:DoneAction
ignoreRealm:yes
newButtonTags:'Action Done Next'
dontShowEmpty:yes
sort:-modified
"></div>
</div>
</div>
<!--}}}-->
!Context
<!--{{{-->
<div class="cols2">
<div class="col">
<div macro="mgtdList title:'Next' tags:'Action && Next && !Done' view:ActionProj
newButtonTags:'Action Next'
where:tiddler.hasActiveProject()||!tiddler.hasParent('Project')
"></div>
</div>
<div class="col">
<div macro="mgtdList title:'Waiting' tags:'Action && [(Waiting For)] && !Done' view:ActionProj
newButtonTags:'Action [(Waiting For)]'
where:tiddler.hasActiveProject()||!tiddler.hasParent('Project')
"></div>
<div macro="mgtdList title:'Future' tags:'Action && Future && !Done' view:ActionProj
newButtonTags:'Action Future'
where:tiddler.hasActiveProject()||!tiddler.hasParent('Project')
"></div>
</div>
</div>
<!--}}}-->
!Contact
<!--{{{-->
<div class="cols2">
<div class="col">
<div macro="mgtdList title:'Delegated Actions' tags:'Action && !Done && [(Waiting For)]' view:ActionProj
ignoreRealm:yes
newButtonTags:'Action [(Waiting For)]'
"></div>
<div macro="mgtdList title:'Associated Actions' tags:'Action && !Done && ![(Waiting For)]' view:ActionProj
ignoreRealm:yes
group:ActionStatus
gView:bold
newButtonTags:'Action'
"></div>
</div>
<div class="col">
<div macro="mgtdList title:'Associated Projects' tags:'Project && !Complete' view:Project
ignoreRealm:yes
group:ProjectStatus
gView:bold
newButtonTags:'Project'
"></div>
<div macro="mgtdList title:'Associated Ticklers' tags:'Tickler && !Actioned' view:Tickler
ignoreRealm:yes
newButtonTags:'Tickler Once'
sort:tickleDate
"></div>
<div macro="mgtdList title:'Done Actions' tags:'Action && Done' view:DoneAction
ignoreRealm:yes
newButtonTags:Done
"></div>
<div macro="mgtdList title:'Completed Projects' tags:'Project && Complete' view:ProjectComplete
ignoreRealm:yes
newButtonTags:'Project'
"></div>
</div>
</div>
<!--}}}-->
!Area
<!--{{{-->
<div class="cols3">
<div class="col">
<div macro="mgtdList title:'Active Projects' tags:'Project && !Complete && !Someday/Maybe' view:Project newButtonTags:'Project Active'
ignoreRealm:yes
"></div>
<!--
for those who wanted actions in their area view
comment the following out if you don't want it
NB under construction, doesn't work at all...
<div macro="mgtdList title:'Next Actions'
mode:global
startTag:Action
tags:'!Done'
group:ActionStatus
gView:bold
newButtonTags:'Action'
view:Action
where:{{'tiddler.actionInArea('+tiddler.title+')'}}
ignoreRealm:yes
"></div>
-->
</div>
<div class="col">
<div macro="mgtdList title:'Someday/Maybe Projects' tags:'Project && !Complete && Someday/Maybe' view:Project newButtonTags:'Project Someday/Maybe'
ignoreRealm:yes
"></div>
</div>
<div class="col">
<div macro="mgtdList title:'Actions (without a project)'
tags:'Action && !Done'
view:Action
newButtonTags:'Action'
group:ActionStatus
gView:bold
ignoreRealm:yes
"></div>
<div macro="mgtdList title:'Completed Projects' tags:'Project && Complete' view:ProjectComplete newButtonTags:'Project Someday/Maybe'
ignoreRealm:yes
"></div>
</div>
</div>
<!--}}}-->
!Reference
<!--{{{-->
<div class="tagglyTagging" macro="tagglyTagging"></div><!--- this makes me happy :) --->
<!--}}}-->
!Ticklers Requiring Action
<!--{{{-->
<!--- included by other sections --->
<div macro="mgtdList title:'Ticklers Requiring Action' tags:'Tickler && !Actioned' view:Tickler newButtonTags:'Tickler Once'
ignoreRealm:yes
dontShowEmpty:yes
where:'tiddler.ticklerIsActive()'
sort:tickleDate
"></div>
<!--}}}-->
!Upcoming Ticklers
<!--{{{-->
<!--- included by other sections --->
<div macro="mgtdList title:'Upcoming Ticklers' tags:'Tickler && !Actioned' view:Tickler newButtonTags:'Tickler Once'
ignoreRealm:yes
where:'!tiddler.ticklerIsActive()'
sort:tickleDate
"></div>
<!--}}}-->
/***
|Name:|TagglyTaggingPlugin|
|Description:|tagglyTagging macro is a replacement for the builtin tagging macro in your ViewTemplate|
|Version:|3.3.1 ($Rev: 9828 $)|
|Date:|$Date: 2009-06-03 21:38:41 +1000 (Wed, 03 Jun 2009) $|
|Source:|http://mptw.tiddlyspot.com/#TagglyTaggingPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!Notes
See http://mptw.tiddlyspot.com/#TagglyTagging
***/
//{{{
merge(String.prototype,{
parseTagExpr: function(debug) {
if (this.trim() == "")
return "(true)";
var anyLogicOp = /(!|&&|\|\||\(|\))/g;
var singleLogicOp = /^(!|&&|\|\||\(|\))$/;
var spaced = this.
// because square brackets in templates are no good
// this means you can use [(With Spaces)] instead of [[With Spaces]]
replace(/\[\(/g," [[").
replace(/\)\]/g,"]] ").
// space things out so we can use readBracketedList. tricky eh?
replace(anyLogicOp," $1 ");
var expr = "";
var tokens = spaced.readBracketedList(false); // false means don't uniq the list. nice one JR!
for (var i=0;i<tokens.length;i++)
if (tokens[i].match(singleLogicOp))
expr += tokens[i];
else
expr += "tiddler.tags.contains('%0')".format([tokens[i].replace(/'/,"\\'")]); // fix single quote bug. still have round bracket bug i think
if (debug)
alert(expr);
return '('+expr+')';
}
});
merge(TiddlyWiki.prototype,{
getTiddlersByTagExpr: function(tagExpr,sortField) {
var result = [];
var expr = tagExpr.parseTagExpr();
store.forEachTiddler(function(title,tiddler) {
if (eval(expr))
result.push(tiddler);
});
if(!sortField)
sortField = "title";
result.sort(function(a,b) {return a[sortField] < b[sortField] ? -1 : (a[sortField] == b[sortField] ? 0 : +1);});
return result;
}
});
config.taggly = {
// for translations
lingo: {
labels: {
asc: "\u2191", // down arrow
desc: "\u2193", // up arrow
title: "title",
modified: "modified",
created: "created",
show: "+",
hide: "-",
normal: "normal",
group: "group",
commas: "commas",
sitemap: "sitemap",
numCols: "cols\u00b1", // plus minus sign
label: "Tagged as '%0':",
exprLabel: "Matching tag expression '%0':",
excerpts: "excerpts",
descr: "descr",
slices: "slices",
contents: "contents",
sliders: "sliders",
noexcerpts: "title only",
noneFound: "(none)"
},
tooltips: {
title: "Click to sort by title",
modified: "Click to sort by modified date",
created: "Click to sort by created date",
show: "Click to show tagging list",
hide: "Click to hide tagging list",
normal: "Click to show a normal ungrouped list",
group: "Click to show list grouped by tag",
sitemap: "Click to show a sitemap style list",
commas: "Click to show a comma separated list",
numCols: "Click to change number of columns",
excerpts: "Click to show excerpts",
descr: "Click to show the description slice",
slices: "Click to show all slices",
contents: "Click to show entire tiddler contents",
sliders: "Click to show tiddler contents in sliders",
noexcerpts: "Click to show entire title only"
},
tooDeepMessage: "* //sitemap too deep...//"
},
config: {
showTaggingCounts: true,
listOpts: {
// the first one will be the default
sortBy: ["title","modified","created"],
sortOrder: ["asc","desc"],
hideState: ["show","hide"],
listMode: ["normal","group","sitemap","commas"],
numCols: ["1","2","3","4","5","6"],
excerpts: ["noexcerpts","excerpts","descr","slices","contents","sliders"]
},
valuePrefix: "taggly.",
excludeTags: ["excludeLists","excludeTagging"],
excerptSize: 50,
excerptMarker: "/%"+"%/",
siteMapDepthLimit: 25
},
getTagglyOpt: function(title,opt) {
var val = store.getValue(title,this.config.valuePrefix+opt);
return val ? val : this.config.listOpts[opt][0];
},
setTagglyOpt: function(title,opt,value) {
// create it silently if it doesn't exist
if (!store.tiddlerExists(title)) {
store.saveTiddler(title,title,config.views.editor.defaultText.format([title]),config.options.txtUserName,new Date(),"");
// <<tagglyTagging expr:"...">> creates a tiddler to store its display settings
// Make those tiddlers less noticeable by tagging as excludeSearch and excludeLists
// Because we don't want to hide real tags, check that they aren't actually tags before doing so
// Also tag them as tagglyExpression for manageability
// (contributed by RA)
if (!store.getTaggedTiddlers(title).length) {
store.setTiddlerTag(title,true,"excludeSearch");
store.setTiddlerTag(title,true,"excludeLists");
store.setTiddlerTag(title,true,"tagglyExpression");
}
}
// if value is default then remove it to save space
return store.setValue(title, this.config.valuePrefix+opt, value == this.config.listOpts[opt][0] ? null : value);
},
getNextValue: function(title,opt) {
var current = this.getTagglyOpt(title,opt);
var pos = this.config.listOpts[opt].indexOf(current);
// supposed to automagically don't let cols cycle up past the number of items
// currently broken in some situations, eg when using an expression
// lets fix it later when we rewrite for jquery
// the columns thing should be jquery table manipulation probably
var limit = (opt == "numCols" ? store.getTaggedTiddlers(title).length : this.config.listOpts[opt].length);
var newPos = (pos + 1) % limit;
return this.config.listOpts[opt][newPos];
},
toggleTagglyOpt: function(title,opt) {
var newVal = this.getNextValue(title,opt);
this.setTagglyOpt(title,opt,newVal);
},
createListControl: function(place,title,type) {
var lingo = config.taggly.lingo;
var label;
var tooltip;
var onclick;
if ((type == "title" || type == "modified" || type == "created")) {
// "special" controls. a little tricky. derived from sortOrder and sortBy
label = lingo.labels[type];
tooltip = lingo.tooltips[type];
if (this.getTagglyOpt(title,"sortBy") == type) {
label += lingo.labels[this.getTagglyOpt(title,"sortOrder")];
onclick = function() {
config.taggly.toggleTagglyOpt(title,"sortOrder");
return false;
}
}
else {
onclick = function() {
config.taggly.setTagglyOpt(title,"sortBy",type);
config.taggly.setTagglyOpt(title,"sortOrder",config.taggly.config.listOpts.sortOrder[0]);
return false;
}
}
}
else {
// "regular" controls, nice and simple
label = lingo.labels[type == "numCols" ? type : this.getNextValue(title,type)];
tooltip = lingo.tooltips[type == "numCols" ? type : this.getNextValue(title,type)];
onclick = function() {
config.taggly.toggleTagglyOpt(title,type);
return false;
}
}
// hide button because commas don't have columns
if (!(this.getTagglyOpt(title,"listMode") == "commas" && type == "numCols"))
createTiddlyButton(place,label,tooltip,onclick,type == "hideState" ? "hidebutton" : "button");
},
makeColumns: function(orig,numCols) {
var listSize = orig.length;
var colSize = listSize/numCols;
var remainder = listSize % numCols;
var upperColsize = colSize;
var lowerColsize = colSize;
if (colSize != Math.floor(colSize)) {
// it's not an exact fit so..
upperColsize = Math.floor(colSize) + 1;
lowerColsize = Math.floor(colSize);
}
var output = [];
var c = 0;
for (var j=0;j<numCols;j++) {
var singleCol = [];
var thisSize = j < remainder ? upperColsize : lowerColsize;
for (var i=0;i<thisSize;i++)
singleCol.push(orig[c++]);
output.push(singleCol);
}
return output;
},
drawTable: function(place,columns,theClass) {
var newTable = createTiddlyElement(place,"table",null,theClass);
var newTbody = createTiddlyElement(newTable,"tbody");
var newTr = createTiddlyElement(newTbody,"tr");
for (var j=0;j<columns.length;j++) {
var colOutput = "";
for (var i=0;i<columns[j].length;i++)
colOutput += columns[j][i];
var newTd = createTiddlyElement(newTr,"td",null,"tagglyTagging"); // todo should not need this class
wikify(colOutput,newTd);
}
return newTable;
},
createTagglyList: function(place,title,isTagExpr) {
switch(this.getTagglyOpt(title,"listMode")) {
case "group": return this.createTagglyListGrouped(place,title,isTagExpr); break;
case "normal": return this.createTagglyListNormal(place,title,false,isTagExpr); break;
case "commas": return this.createTagglyListNormal(place,title,true,isTagExpr); break;
case "sitemap":return this.createTagglyListSiteMap(place,title,isTagExpr); break;
}
},
getTaggingCount: function(title,isTagExpr) {
// thanks to Doug Edmunds
if (this.config.showTaggingCounts) {
var tagCount = config.taggly.getTiddlers(title,'title',isTagExpr).length;
if (tagCount > 0)
return " ("+tagCount+")";
}
return "";
},
getTiddlers: function(titleOrExpr,sortBy,isTagExpr) {
return isTagExpr ? store.getTiddlersByTagExpr(titleOrExpr,sortBy) : store.getTaggedTiddlers(titleOrExpr,sortBy);
},
getExcerpt: function(inTiddlerTitle,title,indent) {
if (!indent)
indent = 1;
var displayMode = this.getTagglyOpt(inTiddlerTitle,"excerpts");
var t = store.getTiddler(title);
if (t && displayMode == "excerpts") {
var text = t.text.replace(/\n/," ");
var marker = text.indexOf(this.config.excerptMarker);
if (marker != -1) {
return " {{excerpt{<nowiki>" + text.substr(0,marker) + "</nowiki>}}}";
}
else if (text.length < this.config.excerptSize) {
return " {{excerpt{<nowiki>" + t.text + "</nowiki>}}}";
}
else {
return " {{excerpt{<nowiki>" + t.text.substr(0,this.config.excerptSize) + "..." + "</nowiki>}}}";
}
}
else if (t && displayMode == "contents") {
return "\n{{contents indent"+indent+"{\n" + t.text + "\n}}}";
}
else if (t && displayMode == "sliders") {
return "<slider slide>\n{{contents{\n" + t.text + "\n}}}\n</slider>";
}
else if (t && displayMode == "descr") {
var descr = store.getTiddlerSlice(title,'Description');
return descr ? " {{excerpt{" + descr + "}}}" : "";
}
else if (t && displayMode == "slices") {
var result = "";
var slices = store.calcAllSlices(title);
for (var s in slices)
result += "|%0|<nowiki>%1</nowiki>|\n".format([s,slices[s]]);
return result ? "\n{{excerpt excerptIndent{\n" + result + "}}}" : "";
}
return "";
},
notHidden: function(t,inTiddler) {
if (typeof t == "string")
t = store.getTiddler(t);
return (!t || !t.tags.containsAny(this.config.excludeTags) ||
(inTiddler && this.config.excludeTags.contains(inTiddler)));
},
// this is for normal and commas mode
createTagglyListNormal: function(place,title,useCommas,isTagExpr) {
var list = config.taggly.getTiddlers(title,this.getTagglyOpt(title,"sortBy"),isTagExpr);
if (this.getTagglyOpt(title,"sortOrder") == "desc")
list = list.reverse();
var output = [];
var first = true;
for (var i=0;i<list.length;i++) {
if (this.notHidden(list[i],title)) {
var countString = this.getTaggingCount(list[i].title);
var excerpt = this.getExcerpt(title,list[i].title);
if (useCommas)
output.push((first ? "" : ", ") + "[[" + list[i].title + "]]" + countString + excerpt);
else
output.push("*[[" + list[i].title + "]]" + countString + excerpt + "\n");
first = false;
}
}
return this.drawTable(place,
this.makeColumns(output,useCommas ? 1 : parseInt(this.getTagglyOpt(title,"numCols"))),
useCommas ? "commas" : "normal");
},
// this is for the "grouped" mode
createTagglyListGrouped: function(place,title,isTagExpr) {
var sortBy = this.getTagglyOpt(title,"sortBy");
var sortOrder = this.getTagglyOpt(title,"sortOrder");
var list = config.taggly.getTiddlers(title,sortBy,isTagExpr);
if (sortOrder == "desc")
list = list.reverse();
var leftOvers = []
for (var i=0;i<list.length;i++)
leftOvers.push(list[i].title);
var allTagsHolder = {};
for (var i=0;i<list.length;i++) {
for (var j=0;j<list[i].tags.length;j++) {
if (list[i].tags[j] != title) { // not this tiddler
if (this.notHidden(list[i].tags[j],title)) {
if (!allTagsHolder[list[i].tags[j]])
allTagsHolder[list[i].tags[j]] = "";
if (this.notHidden(list[i],title)) {
allTagsHolder[list[i].tags[j]] += "**[["+list[i].title+"]]"
+ this.getTaggingCount(list[i].title) + this.getExcerpt(title,list[i].title) + "\n";
leftOvers.setItem(list[i].title,-1); // remove from leftovers. at the end it will contain the leftovers
}
}
}
}
}
var allTags = [];
for (var t in allTagsHolder)
allTags.push(t);
var sortHelper = function(a,b) {
if (a == b) return 0;
if (a < b) return -1;
return 1;
};
allTags.sort(function(a,b) {
var tidA = store.getTiddler(a);
var tidB = store.getTiddler(b);
if (sortBy == "title") return sortHelper(a,b);
else if (!tidA && !tidB) return 0;
else if (!tidA) return -1;
else if (!tidB) return +1;
else return sortHelper(tidA[sortBy],tidB[sortBy]);
});
var leftOverOutput = "";
for (var i=0;i<leftOvers.length;i++)
if (this.notHidden(leftOvers[i],title))
leftOverOutput += "*[["+leftOvers[i]+"]]" + this.getTaggingCount(leftOvers[i]) + this.getExcerpt(title,leftOvers[i]) + "\n";
var output = [];
if (sortOrder == "desc")
allTags.reverse();
else if (leftOverOutput != "")
// leftovers first...
output.push(leftOverOutput);
for (var i=0;i<allTags.length;i++)
if (allTagsHolder[allTags[i]] != "")
output.push("*[["+allTags[i]+"]]" + this.getTaggingCount(allTags[i]) + this.getExcerpt(title,allTags[i]) + "\n" + allTagsHolder[allTags[i]]);
if (sortOrder == "desc" && leftOverOutput != "")
// leftovers last...
output.push(leftOverOutput);
return this.drawTable(place,
this.makeColumns(output,parseInt(this.getTagglyOpt(title,"numCols"))),
"grouped");
},
// used to build site map
treeTraverse: function(title,depth,sortBy,sortOrder,isTagExpr) {
var list = config.taggly.getTiddlers(title,sortBy,isTagExpr);
if (sortOrder == "desc")
list.reverse();
var indent = "";
for (var j=0;j<depth;j++)
indent += "*"
var childOutput = "";
if (depth > this.config.siteMapDepthLimit)
childOutput += indent + this.lingo.tooDeepMessage + "\n";
else
for (var i=0;i<list.length;i++)
if (list[i].title != title)
if (this.notHidden(list[i].title,this.config.inTiddler))
childOutput += this.treeTraverse(list[i].title,depth+1,sortBy,sortOrder,false);
if (depth == 0)
return childOutput;
else
return indent + "[["+title+"]]" + this.getTaggingCount(title) + this.getExcerpt(this.config.inTiddler,title,depth) + "\n" + childOutput;
},
// this if for the site map mode
createTagglyListSiteMap: function(place,title,isTagExpr) {
this.config.inTiddler = title; // nasty. should pass it in to traverse probably
var output = this.treeTraverse(title,0,this.getTagglyOpt(title,"sortBy"),this.getTagglyOpt(title,"sortOrder"),isTagExpr);
return this.drawTable(place,
this.makeColumns(output.split(/(?=^\*\[)/m),parseInt(this.getTagglyOpt(title,"numCols"))), // regexp magic
"sitemap"
);
},
macros: {
tagglyTagging: {
handler: function (place,macroName,params,wikifier,paramString,tiddler) {
var parsedParams = paramString.parseParams("tag",null,true);
var refreshContainer = createTiddlyElement(place,"div");
// do some refresh magic to make it keep the list fresh - thanks Saq
refreshContainer.setAttribute("refresh","macro");
refreshContainer.setAttribute("macroName",macroName);
var tag = getParam(parsedParams,"tag");
var expr = getParam(parsedParams,"expr");
if (expr) {
refreshContainer.setAttribute("isTagExpr","true");
refreshContainer.setAttribute("title",expr);
refreshContainer.setAttribute("showEmpty","true");
}
else {
refreshContainer.setAttribute("isTagExpr","false");
if (tag) {
refreshContainer.setAttribute("title",tag);
refreshContainer.setAttribute("showEmpty","true");
}
else {
refreshContainer.setAttribute("title",tiddler.title);
refreshContainer.setAttribute("showEmpty","false");
}
}
this.refresh(refreshContainer);
},
refresh: function(place) {
var title = place.getAttribute("title");
var isTagExpr = place.getAttribute("isTagExpr") == "true";
var showEmpty = place.getAttribute("showEmpty") == "true";
removeChildren(place);
addClass(place,"tagglyTagging");
var countFound = config.taggly.getTiddlers(title,'title',isTagExpr).length
if (countFound > 0 || showEmpty) {
var lingo = config.taggly.lingo;
config.taggly.createListControl(place,title,"hideState");
if (config.taggly.getTagglyOpt(title,"hideState") == "show") {
createTiddlyElement(place,"span",null,"tagglyLabel",
isTagExpr ? lingo.labels.exprLabel.format([title]) : lingo.labels.label.format([title]));
config.taggly.createListControl(place,title,"title");
config.taggly.createListControl(place,title,"modified");
config.taggly.createListControl(place,title,"created");
config.taggly.createListControl(place,title,"listMode");
config.taggly.createListControl(place,title,"excerpts");
config.taggly.createListControl(place,title,"numCols");
config.taggly.createTagglyList(place,title,isTagExpr);
if (countFound == 0 && showEmpty)
createTiddlyElement(place,"div",null,"tagglyNoneFound",lingo.labels.noneFound);
}
}
}
}
},
// todo fix these up a bit
styles: [
"/*{{{*/",
"/* created by TagglyTaggingPlugin */",
".tagglyTagging { padding-top:0.5em; }",
".tagglyTagging li.listTitle { display:none; }",
".tagglyTagging ul {",
" margin-top:0px; padding-top:0.5em; padding-left:2em;",
" margin-bottom:0px; padding-bottom:0px;",
"}",
".tagglyTagging { vertical-align: top; margin:0px; padding:0px; }",
".tagglyTagging table { margin:0px; padding:0px; }",
".tagglyTagging .button { visibility:hidden; margin-left:3px; margin-right:3px; }",
".tagglyTagging .button, .tagglyTagging .hidebutton {",
" color:[[ColorPalette::TertiaryLight]]; font-size:90%;",
" border:0px; padding-left:0.3em;padding-right:0.3em;",
"}",
".tagglyTagging .button:hover, .hidebutton:hover, ",
".tagglyTagging .button:active, .hidebutton:active {",
" border:0px; background:[[ColorPalette::TertiaryPale]]; color:[[ColorPalette::TertiaryDark]];",
"}",
".selected .tagglyTagging .button { visibility:visible; }",
".tagglyTagging .hidebutton { color:[[ColorPalette::Background]]; }",
".selected .tagglyTagging .hidebutton { color:[[ColorPalette::TertiaryLight]] }",
".tagglyLabel { color:[[ColorPalette::TertiaryMid]]; font-size:90%; }",
".tagglyTagging ul {padding-top:0px; padding-bottom:0.5em; margin-left:1em; }",
".tagglyTagging ul ul {list-style-type:disc; margin-left:-1em;}",
".tagglyTagging ul ul li {margin-left:0.5em; }",
".editLabel { font-size:90%; padding-top:0.5em; }",
".tagglyTagging .commas { padding-left:1.8em; }",
"/* not technically tagglytagging but will put them here anyway */",
".tagglyTagged li.listTitle { display:none; }",
".tagglyTagged li { display: inline; font-size:90%; }",
".tagglyTagged ul { margin:0px; padding:0px; }",
".excerpt { color:[[ColorPalette::TertiaryDark]]; }",
".excerptIndent { margin-left:4em; }",
"div.tagglyTagging table,",
"div.tagglyTagging table tr,",
"td.tagglyTagging",
" {border-style:none!important; }",
".tagglyTagging .contents { border-bottom:2px solid [[ColorPalette::TertiaryPale]]; padding:0 1em 1em 0.5em;",
" margin-bottom:0.5em; }",
".tagglyTagging .indent1 { margin-left:3em; }",
".tagglyTagging .indent2 { margin-left:4em; }",
".tagglyTagging .indent3 { margin-left:5em; }",
".tagglyTagging .indent4 { margin-left:6em; }",
".tagglyTagging .indent5 { margin-left:7em; }",
".tagglyTagging .indent6 { margin-left:8em; }",
".tagglyTagging .indent7 { margin-left:9em; }",
".tagglyTagging .indent8 { margin-left:10em; }",
".tagglyTagging .indent9 { margin-left:11em; }",
".tagglyTagging .indent10 { margin-left:12em; }",
".tagglyNoneFound { margin-left:2em; color:[[ColorPalette::TertiaryMid]]; font-size:90%; font-style:italic; }",
"/*}}}*/",
""].join("\n"),
init: function() {
merge(config.macros,this.macros);
config.shadowTiddlers["TagglyTaggingStyles"] = this.styles;
store.addNotification("TagglyTaggingStyles",refreshStyles);
}
};
config.taggly.init();
//}}}
/***
InlineSlidersPlugin
By Saq Imtiaz
http://tw.lewcid.org/sandbox/#InlineSlidersPlugin
// syntax adjusted to not clash with NestedSlidersPlugin
// added + syntax to start open instead of closed
***/
//{{{
config.formatters.unshift( {
name: "inlinesliders",
// match: "\\+\\+\\+\\+|\\<slider",
match: "\\<slider",
// lookaheadRegExp: /(?:\+\+\+\+|<slider) (.*?)(?:>?)\n((?:.|\n)*?)\n(?:====|<\/slider>)/mg,
lookaheadRegExp: /(?:<slider)(\+?) (.*?)(?:>)\n((?:.|\n)*?)\n(?:<\/slider>)/mg,
handler: function(w) {
this.lookaheadRegExp.lastIndex = w.matchStart;
var lookaheadMatch = this.lookaheadRegExp.exec(w.source)
if(lookaheadMatch && lookaheadMatch.index == w.matchStart ) {
var btn = createTiddlyButton(w.output,lookaheadMatch[2] + " "+"\u00BB",lookaheadMatch[2],this.onClickSlider,"button sliderButton");
var panel = createTiddlyElement(w.output,"div",null,"sliderPanel");
panel.style.display = (lookaheadMatch[1] == '+' ? "block" : "none");
wikify(lookaheadMatch[3],panel);
w.nextMatch = lookaheadMatch.index + lookaheadMatch[0].length;
}
},
onClickSlider : function(e) {
if(!e) var e = window.event;
var n = this.nextSibling;
n.style.display = (n.style.display=="none") ? "block" : "none";
return false;
}
});
//}}}
{{cols2{
{{col{
<<tiddler 'Ticklers Requiring Action'>>
<<mgtdList title:'Upcoming Ticklers (next 7 days)'
startTag:Tickler
tags:'!Actioned'
view:Tickler
mode:global
newButtonTags:'Tickler Once'
where:'tiddler.ticklerWillBeActiveWithin(7)'
sort:'tickleDate'
dontShowEmpty:yes
ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>
<<mgtdList title:'Upcoming Ticklers'
startTag:Tickler
tags:'!Actioned'
view:Tickler
mode:global
newButtonTags:'Tickler Once'
where:'(!tiddler.fields.mgtd_date || !tiddler.ticklerIsActive()) && !tiddler.ticklerWillBeActiveWithin(7)'
sort:'tickleDate'
ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>
}}}
{{col{
<<mgtdList
title:'Old Ticklers'
startTag:Tickler
tags:'Actioned'
view:Tickler
mode:global
newButtonTags:'Tickler Actioned Once'
>>
}}}
}}}
{{cols2{
{{col{
<<mgtdList
title:'Ticklers Requiring Action Grouped'
startTag:Tickler
tags:'!Actioned'
view:Tickler
group:Contact
gView:bold
mode:global
newButtonTags:'Tickler Enabled Once'
where:'tiddler.ticklerIsActive()'
sort:'tickleDate'
dontShowEmpty:yes
ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>
<<mgtdList
title:'Upcoming Ticklers Grouped (next 7 days)'
startTag:Tickler
tags:'!Actioned'
view:Tickler
group:Contact
gView:bold
mode:global
newButtonTags:'Tickler Enabled Once'
where:'tiddler.ticklerWillBeActiveWithin(7)'
sort:'tickleDate'
ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>
}}}
{{col{
<<mgtdList
title:'Upcoming Ticklers Grouped'
startTag:Tickler
tags:'!Actioned'
view:Tickler
group:Contact
gView:bold
mode:global
newButtonTags:'Tickler Enabled Once'
where:'(!tiddler.fields.mgtd_date || !tiddler.ticklerIsActive()) && !tiddler.ticklerWillBeActiveWithin(7)'
sort:'tickleDate'
ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>
}}}
}}}
<<mgtdList
title:'Ticklers Requiring Action'
startTag:Tickler
tags:'!Actioned'
view:Tickler
mode:global
newButtonTags:'Tickler Enabled Once'
where:'tiddler.ticklerIsActive()'
sort:'tickleDate'
dontShowEmpty:yes
ignoreRealm:{{config.mGTD.getOptChk('AlertsIgnoreRealm')?'yes':''}}
>>
// for sorting tiddlers
merge(Tiddler.prototype,{
sort_tickleDate: function() {
return this.fields['mgtd_date'] || 'ZZZZZZZZ'; // i think that's enought to make undated tiddlers sort to the end
},
sort_orderSlice: function() {
var orderSlice = store.getTiddlerSlice(this.title,"order");
return orderSlice ? orderSlice : this.title; // so if there's no slice we get sorting by title
},
sort_prioritySlice: function() {
var orderSlice = store.getTiddlerSlice(this.title,"priority");
return orderSlice ? orderSlice : this.title; // so if there's no slice we get sorting by title
}
});
// for displaying tiddlers in lists
// idea: use <<tiddler with:?>>
if (!config.mGTD) config.mGTD = {};
config.mGTD.data = {
starOn: 'data:image/gif;base64,R0lGODlhDwAPAMQfAF9h4RYVnZeQJC0u0lRQU42R6P/7Fv74L05NrRkZxi4tW52XXv71D8nAIWxnjnRxr3NuMJKOluXbBe7kCa2x7UFD1vPoB77D8Jqe6n6B5tvTUr62BMrP8lJPh1xbuv///yH5BAEAAB8ALAAAAAAPAA8AAAWD4CeOWQKMaDpESepi3tFlLgpExlK9RT9ohkYi08N8KhWP8nEwMBwIDyJRSTgO2CaDYcBOCAlMgtDYmhmTDSFQ+HAqgbLZIlAMLqiKw7m1EAYuFQsGEhITEwItKBc/EgIEAhINAUYkCBIQAQMBEGonIwAKa21iCgo7IxQDFRQjF1VtHyEAOw==',
starOff: 'data:image/gif;base64,R0lGODlhDwAPALMPAP///8zj++r7/7vb/rHW/tPt/9Lk+qzT/rbY/sHh/8Te/N7q+Nzy/7nY/djn+f///yH5BAEAAA8ALAAAAAAPAA8AAARg8MkZjpo4k0KyNwlQBB42MICAfEF7APDRBsYzIEkewGKeDI1DgUckMg6GTdFIqC0QgyUgQVhgGkOi4OBBCJYdzILAywIGNcoOgCAQvowBRpE4kgzCQgPjQCAcEwsNTRIRADs=',
unicodeStar: "\u2605" // "black star"
};
merge(Tiddler.prototype,{
render_Action: function() { return this.renderUtil(
'{{action{'+
'<<toggleTag Done [[%0]] ->>'+
'<<multiToggleTag tag:ActionStatus title:[[%0]]>>'+
//'<<multiSelectTag tag:Project title:[[%0]]>>'+
//'<<multiCheckboxTag tag:ActionStatus title:[[%0]]>>'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
' [[%0]] '+
'<<deleteTiddler [[%0]]>>'+
'}}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
[
this.title
]
);},
render_Tickler: function() {
var repeatType = this.getByIndex('TicklerRepeatType');
var doneControl = "";
if (repeatType.length == 0 || repeatType.contains('Once')) {
// show normal done checkbox
doneControl = '<<toggleTag Actioned [[%0]] ->>';
}
else if (repeatType.contains('Daily')) { doneControl = '<<addDay [[%0]]>>' }
else if (repeatType.contains('Weekly')) { doneControl = '<<addWeek [[%0]]>>' }
else if (repeatType.contains('Fortnightly')) { doneControl = '<<addFortnight [[%0]]>>' }
else if (repeatType.contains('Monthly')) { doneControl = '<<addMonth [[%0]]>>' }
else if (repeatType.contains('Yearly')) { doneControl = '<<addYear [[%0]]>>' }
var pLink = "";
if (config.mGTD.getOptChk('FullContactInActionLists')) {
pLink += "{{projLinkFull{<<linkToParent Project [[title]] [[%0]]>>}}}".format([this.title]);
}
else {
pLink += "{{projLink{<<linkToParent Project '[P]' [[%0]]>>}}}".format([this.title]);
}
return this.renderUtil(
'{{tickler{'+
'%1'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
'<<dateChooser [[%0]]>>'+
' [[%0]]'+
'<<deleteTiddler [[%0]]>>'+
'}}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}'+
' %2',
[
this.title,
doneControl.format([this.title]),
pLink
]
);},
render_Project: function() { return this.renderUtil(
'{{project{'+
'<<toggleTag Complete [[%0]] ->>'+
'<<multiToggleTag tag:ProjectStatus title:[[%0]]>>'+
//'<<multiSelectTag tag:Project title:[[%0]]>>'+
//'<<multiCheckboxTag tag:ActionStatus title:[[%0]]>>'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
' [[%0]] }}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}'+
"{{projLink{<<linkToParent Project '[P]' [[%0]]>>}}}"+
"{{projLink{<<linkToParent Contact '[C]' [[%0]]>>}}}"+
"",
[
this.title
]
);},
render_ProjectArea: function() {
var aLink = "";
return this.renderUtil(
'{{project{'+
'<<toggleTag Complete [[%0]] ->>'+
'<<multiToggleTag tag:ProjectStatus title:[[%0]]>>'+
//'<<multiSelectTag tag:Project title:[[%0]]>>'+
//'<<multiCheckboxTag tag:ActionStatus title:[[%0]]>>'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
' [[%0]] }}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}'+
"{{projLink{<<linkToParent Area '[A]' [[%0]]>>}}}"+
"{{projLink{<<linkToParent Project '[P]' [[%0]]>>}}}"+
"{{projLink{<<linkToParent Contact '[C]' [[%0]]>>}}}"+
"",
[
this.title,
aLink
]
);},
render_ProjectBare: function() { return this.renderUtil(
'{{project{'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
' [[%0]] }}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
[
this.title
]
);},
render_ProjectComplete: function() { return this.renderUtil(
'{{project{'+
'<<toggleTag Complete [[%0]] ->>'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
' [[%0]] }}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
[
this.title
]
);},
render_ActionProj: function() {
// actually it's not going to be easy to have
// an action in more than one project
// but just in case....
var pLink = "";
if (config.mGTD.getOptChk('FullAreaInActionLists')) {
pLink += "{{projLinkFull{<<linkToParent Area [[title]] [[%0]]>>}}}".format([this.title]);
}
else {
pLink += "{{projLink{<<linkToParent Area '[A]' [[%0]]>>}}}".format([this.title]);
}
if (config.mGTD.getOptChk('FullProjectInActionLists')) {
pLink += "{{projLinkFull{<<linkToParent Project [[title]] [[%0]]>>}}}".format([this.title]);
}
else {
pLink += "{{projLink{<<linkToParent Project '[P]' [[%0]]>>}}}".format([this.title]);
}
if (config.mGTD.getOptChk('FullContactInActionLists')) {
pLink += "{{projLinkFull{<<linkToParent Contact [[title]] [[%0]]>>}}}".format([this.title]);
}
else {
pLink += "{{projLink{<<linkToParent Contact '[C]' [[%0]]>>}}}".format([this.title]);
}
return this.renderUtil(
'{{action{'+
'<<toggleTag Done [[%0]] ->>'+
'<<multiToggleTag tag:ActionStatus title:[[%0]]>>'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
' [[%0]]'+
'<<deleteTiddler [[%0]]>>'+
'}}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}'+
' %1',
[
this.title,
pLink
]
);},
render_DoneAction: function() { return this.renderUtil(
'{{action{'+
'<<toggleTag Done [[%0]] ->>'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
' [[%0]] '+
'<<deleteTiddler [[%0]]>>'+
'}}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
[
this.title
]
);},
render_ProjectHeading: function() { return this.renderUtil(
'{{project{'+
'[[%0]] '+
'<<toggleTag Complete [[%0]] ->>'+
'@@font-size:80%;<<multiToggleTag tag:ProjectStatus title:[[%0]]>>@@'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
'}}}',
[
this.title
]
);},
render_Context: function() { return this.renderUtil(
'[[%0]]',
[
this.title
]
);},
render_plain: function() { return this.renderUtil(
'{{plain{[[%0]]}}}',
[
this.title
]
);},
render_star: function() { return this.renderUtil(
'{{plain{'+
'<<singleToggleTag tag:Starred title:[[%0]]>>'+
'[[%0]]}}}'+
'{{notesLink{<<showNotesIcon [[%0]]>>}}}',
[
this.title
]
);},
// TODO. this seems stupid
render_bold: function() { return this.renderUtil(
"[[%0]]",
[
this.title
]
);}
});
!Project
<!--{{{-->
<div class="projectcontrols controls controlstint">
<div style="float:right;" class="smaller">
<span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
<span macro="tag Project"></span><span macro="help Project"></span>
</div>
<div>
<span macro="toggleTag Complete . -"></span>
<span class='title' macro='view title'></span>
<span macro="miniTag"></span>
<span macro="linkToParent Area '[A]'"></span>
<span macro="linkToParent Project '[P]'"></span>
<span macro="singleToggleTag tag:Starred"></span>
[[MonkeyGTDTheme##Subtitle]]
</div>
<div macro="hideWhenTagged Complete" style="padding-top:0.25em;padding-bottom:0.25em;">
<span macro="multiSelectTag Priority allowNone:on"></span>
<span macro="multiToggleTag ProjectStatus longVersion:on"></span>
</div>
<div>
<div class="floatright" macro="convertToFromTickler"><br/></div>
<div class="floatright" macro="deleteAllTagged 'delete project' '' 'delete'"><br/></div>
<div class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
<div class="floatleft"><span class="label">Subproject of</span>:<br><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
<div class="floatleft"><span class="label">Associated contact</span>:<br><span macro="multiSelectTag Contact allowNone:on"></span><span macro="linkToParent Contact"></span></div>
<div class="clearboth"></div>
</div>
</div>
<!--}}}-->
!Action
<!--{{{-->
<div class="actioncontrols controls controlstint">
<div style="float:right;" class="smaller">
<span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
<span macro="tag Action"></span><span macro="help Action"></span>
</div>
<div>
<span macro="toggleTag Done . -"></span>
<span class='title' macro='view title'></span>
<span macro="miniTag"></span>
<span macro="linkToParent Area '[A]'"></span>
<span macro="linkToParent Project '[P]'"></span>
<span macro="singleToggleTag tag:Starred"></span>
[[MonkeyGTDTheme##Subtitle]]
</div>
<div macro="hideWhenTagged Done" style="padding-top:0.25em;padding-bottom:0.25em;">
<span macro="multiToggleTag ActionStatus longVersion:on"></span>
</div>
<div macro="showWhen config.mGTD.getOptChk('MultipleContexts')">
<span class="label">Context:</span><br/><span class="unboldLinks" macro="groupOfSingleToggleTags Context useCheckbox:yes"></span>
</div>
<div>
<div class="floatright" macro="convertToFromTickler"><br/></div>
<div class="floatright" macro="convertActionToSubProj"><br/></div>
<div class="floatright" macro="convertActionToReference"><br/></div>
<div class="floatleft" macro="else"><span class="label">Context:</span><br/><span macro="multiSelectTag Context allowNone:on"></span><span macro="linkToParent Context"></span></div>
<div class="floatleft"><span class="label">Project:</span><br/><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
<div macro="hideWhen tiddler.hasParent('Project')" class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
<div class="floatleft">
<span macro="hideWhenTaggedAny 'Waiting For' 'Done'" class="label">Associated contact:</span>
<span macro="else" class="label">Delegated to/waiting on:</span><br>
<span macro="multiSelectTag Contact allowNone:on"></span><span macro="linkToParent Contact"></span>
</div>
<br style="clear:left"/>
<div class="floatleft">
<span class="label">Depends on:</span><br/><span macro="multiSelectTag Action allowNone:on"></span><span macro="linkToParent Action"></span>
<!-- fixme. broken in 2.4.1 but works in 2.4.3?: <span macro="newSavedTiddler title:'new dependent action' label:'+ dependent action' tag:{{'Action Future [['+config.macros.mgtdList.getRealm()+']] [['+tiddler.getParent('Context')+']] [['+tiddler.getParent('Project')+']] [['+tiddler.title +']]'}}"></span> -->
</div>
<div class="clearboth"></div>
</div>
</div>
<!--}}}-->
!Tickler
<!--{{{-->
<div class="ticklercontrols controls controlstint">
<div style="float:right;" class="smaller">
<span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
<span macro="tag Tickler"></span><span macro="help Tickler"></span>
</div>
<div>
<span macro="showWhen tiddler.tags.contains('Once') || !tiddler.hasParent('TicklerRepeatType')">
<span macro="toggleTag Actioned . -"></span>
</span>
<span macro="showWhenTagged 'Daily'" ><span macro="addDay"></span></span>
<span macro="showWhenTagged 'Weekly'" ><span macro="addWeek"></span></span>
<span macro="showWhenTagged 'Fortnightly'" ><span macro="addFortnight"></span></span>
<span macro="showWhenTagged 'Monthly'" ><span macro="addMonth"></span></span>
<span macro="showWhenTagged 'Yearly'" ><span macro="addYear"></span></span>
<span class='title' macro='view title'></span>
<span macro="linkToParent Area '[A]'"></span>
<span macro="linkToParent Project '[P]'"></span>
<span macro="singleToggleTag tag:Starred"></span>
[[MonkeyGTDTheme##Subtitle]]
</div>
<div macro="hideWhenTagged Actioned" style="padding-top:0.25em;padding-bottom:0.25em;">
<span macro="multiToggleTag TicklerRepeatType longVersion:on"></span>
</div>
<div>
<div class="floatleft"><span class="label">Tickler date:</span><br/><span macro="dateChooser"></span></div>
<div class="floatleft buttonsLikeLinks"><br>
<span macro="addDay"></span>
<span macro="addWeek"></span>
<span macro="addMonth"></span>
<span macro="addYear"></span>
</div>
<div class="clearboth"></div>
</div>
<div>
<div class="floatright" macro="convertToFromTickler"><br/></div>
<div class="floatleft"><span class="label">Project:</span><br/><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
<div macro="hideWhen tiddler.hasParent('Project')" class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
<div class="floatleft"><span class="label">Associated contact</span>:<br><span macro="multiSelectTag Contact allowNone:on"></span><span macro="linkToParent Contact"></span></div>
<div class="clearboth"></div>
</div>
</div>
<!--}}}-->
!View
<!--{{{-->
<div class="viewcontrols controls">
<div>
<span class='title' macro='view title'></span><span macro="help"></span>
</div>
</div>
<!--}}}-->
!Context
<!--{{{-->
<div class="contextcontrols controls">
<div style="float:right;" class="smaller">
<span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
<span macro="tag Context"></span><span macro="help Context"></span>
</div>
<div>
<span class='title' macro='view title'></span>
<span macro="miniTag"></span>
<span macro="singleToggleTag tag:Starred"></span>
</div>
</div>
<!--}}}-->
!Area
<!--{{{-->
<div class="areacontrols controls">
<div style="float:right;" class="smaller">
<span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
<span macro="tag Area"></span><span macro="help Area"></span>
</div>
<div>
<span class='title' macro='view title'></span>
<span macro="miniTag"></span>
<span macro="singleToggleTag tag:Starred"></span>
</div>
</div>
<!--}}}-->
!Realm
<!--{{{-->
<div class="realmcontrols controls">
<div style="float:right;" class="smaller">
<span macro="tag Realm"></span><span macro="help Realm"></span>
</div>
<div>
<span class='title' macro='view title'></span>
</div>
</div>
<!--}}}-->
!Reference
<!--{{{-->
<div class="referencecontrols controls controlstint">
<div style="float:right;" class="smaller">
<span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
<span macro="tag Reference"></span><span macro="help Reference"></span>
</div>
<div>
<span class='title' macro='view title'></span>
<span macro="linkToParent Area '[A]'"></span>
<span macro="linkToParent Project '[P]'"></span>
<span macro="singleToggleTag tag:Starred"></span>
[[MonkeyGTDTheme##Subtitle]]
</div>
<div>
<div class="floatleft"><span class="label">Project:</span><br><span macro="multiSelectTag Project allowNone:on"></span><span macro="linkToParent Project"></span></div>
<div macro="hideWhen tiddler.hasParent('Project')" class="floatleft"><span class="label">Area:</span><br><span macro="multiSelectTag Area allowNone:on"></span><span macro="linkToParent Area"></span></div>
</div>
<div class="clearboth"></div>
<div style="padding-top:1em;">
Double click or click "edit" to edit. Use "new here" to make sub item.
</div>
</div>
<!--}}}-->
!Contact
<!--{{{-->
<div class="contactcontrols controls">
<div style="float:right;" class="smaller">
<span class="label">Realm:</span><span macro="multiSelectTag Realm allowNone:on"></span>
<span macro="tag Contact"></span><span macro="help Contact"></span>
</div>
<div>
<span class='title' macro='view title'></span>
<span macro="miniTag"></span>
<span macro="singleToggleTag tag:Starred"></span>
[[MonkeyGTDTheme##Subtitle]]
</div>
</div>
<!--}}}-->
<div macro="showWhenTagged 'Project'">[[TitleButtons##Project]]</div>
<div macro="showWhenTagged 'Action'">[[TitleButtons##Action]]</div>
<div macro="showWhenTagged 'Tickler'">[[TitleButtons##Tickler]]</div>
<div macro="showWhenTagged 'View'">[[TitleButtons##View]]</div>
<div macro="showWhenTagged 'Context'">[[TitleButtons##Context]]</div>
<div macro="showWhenTagged 'Area'">[[TitleButtons##Area]]</div>
<div macro="showWhenTagged 'Realm'">[[TitleButtons##Realm]]</div>
<div macro="showWhenTagged 'Reference'">[[TitleButtons##Reference]]</div>
<div macro="showWhenTagged 'Contact'">[[TitleButtons##Contact]]</div>
// Created by Saq. Taken from tw.lewcid.org
config.macros.toggleSideBar={};
config.macros.toggleSideBar.settings={
styleHide : "#sidebar { display: none;}\n"+"#contentWrapper #displayArea { margin-right: 1em;}\n"+"",
styleShow : " ",
arrow1: "<<",
arrow2: ">>"
//arrow1: "�",
//arrow2: "�"
};
config.macros.toggleSideBar.handler=function (place,macroName,params,wikifier,paramString,tiddler)
{
var tooltip= params[1]||'toggle sidebar';
var mode = (params[2] && params[2]=="hide")? "hide":"show";
var arrow = (mode == "hide")? this.settings.arrow1:this.settings.arrow2;
var label= (params[0]&¶ms[0]!='.')?params[0]+" "+arrow:arrow;
var theBtn = createTiddlyButton(place,label,tooltip,this.onToggleSideBar,"button HideSideBarButton");
if (mode == "hide")
{
(document.getElementById("sidebar")).setAttribute("toggle","hide");
setStylesheet(this.settings.styleHide,"ToggleSideBarStyles");
}
};
config.macros.toggleSideBar.onToggleSideBar = function(){
var sidebar = document.getElementById("sidebar");
var settings = config.macros.toggleSideBar.settings;
if (sidebar.getAttribute("toggle")=='hide')
{
setStylesheet(settings.styleShow,"ToggleSideBarStyles");
sidebar.setAttribute("toggle","show");
this.firstChild.data= (this.firstChild.data).replace(settings.arrow1,settings.arrow2);
}
else
{
setStylesheet(settings.styleHide,"ToggleSideBarStyles");
sidebar.setAttribute("toggle","hide");
this.firstChild.data= (this.firstChild.data).replace(settings.arrow2,settings.arrow1);
}
return false;
}
/***
|Name:|ToggleTagPlugin|
|Description:|Makes a checkbox which toggles a tag in a tiddler|
|Version:|3.1.0 ($Rev: 4907 $)|
|Date:|$Date: 2008-05-13 03:15:46 +1000 (Tue, 13 May 2008) $|
|Source:|http://mptw.tiddlyspot.com/#ToggleTagPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Usage
{{{<<toggleTag }}}//{{{TagName TiddlerName LabelText}}}//{{{>>}}}
* TagName - the tag to be toggled, default value "checked"
* TiddlerName - the tiddler to toggle the tag in, default value the current tiddler
* LabelText - the text (gets wikified) to put next to the check box, default value is '{{{[[TagName]]}}}' or '{{{[[TagName]] [[TiddlerName]]}}}'
(If a parameter is '.' then the default will be used)
* TouchMod flag - if non empty then touch the tiddlers mod date. Note, can set config.toggleTagAlwaysTouchModDate to always touch mod date
!!Examples
|Code|Description|Example|h
|{{{<<toggleTag>>}}}|Toggles the default tag (checked) in this tiddler|<<toggleTag>>|
|{{{<<toggleTag TagName>>}}}|Toggles the TagName tag in this tiddler|<<toggleTag TagName>>|
|{{{<<toggleTag TagName TiddlerName>>}}}|Toggles the TagName tag in the TiddlerName tiddler|<<toggleTag TagName TiddlerName>>|
|{{{<<toggleTag TagName TiddlerName 'click me'>>}}}|Same but with custom label|<<toggleTag TagName TiddlerName 'click me'>>|
|{{{<<toggleTag . . 'click me'>>}}}|dot means use default value|<<toggleTag . . 'click me'>>|
!!Notes
* If TiddlerName doesn't exist it will be silently created
* Set label to '-' to specify no label
* See also http://mgtd-alpha.tiddlyspot.com/#ToggleTag2
!!Known issues
* Doesn't smoothly handle the case where you toggle a tag in a tiddler that is current open for editing
* Should convert to use named params
***/
//{{{
if (config.toggleTagAlwaysTouchModDate == undefined) config.toggleTagAlwaysTouchModDate = false;
merge(config.macros,{
toggleTag: {
createIfRequired: true,
shortLabel: "[[%0]]",
longLabel: "[[%0]] [[%1]]",
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var tiddlerTitle = tiddler ? tiddler.title : '';
var tag = (params[0] && params[0] != '.') ? params[0] : "checked";
var title = (params[1] && params[1] != '.') ? params[1] : tiddlerTitle;
var defaultLabel = (title == tiddlerTitle ? this.shortLabel : this.longLabel);
var label = (params[2] && params[2] != '.') ? params[2] : defaultLabel;
var touchMod = (params[3] && params[3] != '.') ? params[3] : "";
label = (label == '-' ? '' : label); // dash means no label
var theTiddler = (title == tiddlerTitle ? tiddler : store.getTiddler(title));
var cb = createTiddlyCheckbox(place, label.format([tag,title]), theTiddler && theTiddler.isTagged(tag), function(e) {
if (!store.tiddlerExists(title)) {
if (config.macros.toggleTag.createIfRequired) {
var content = store.getTiddlerText(title); // just in case it's a shadow
store.saveTiddler(title,title,content?content:"",config.options.txtUserName,new Date(),null);
}
else
return false;
}
if ((touchMod != "" || config.toggleTagAlwaysTouchModDate) && theTiddler)
theTiddler.modified = new Date();
store.setTiddlerTag(title,this.checked,tag);
return true;
});
}
}
});
//}}}
This interface to exist in production only.
/***
Description: Contains the stuff you need to use Tiddlyspot
Note, you also need UploadPlugin, PasswordOptionPlugin and LoadRemoteFileThroughProxy
from http://tiddlywiki.bidix.info for a complete working Tiddlyspot site.
***/
//{{{
// edit this if you are migrating sites or retrofitting an existing TW
config.tiddlyspotSiteId = 'dlt';
// make it so you can by default see edit controls via http
config.options.chkHttpReadOnly = false;
window.readOnly = false; // make sure of it (for tw 2.2)
window.showBackstage = true; // show backstage too
// disable autosave in d3
if (window.location.protocol != "file:")
config.options.chkGTDLazyAutoSave = false;
// tweak shadow tiddlers to add upload button, password entry box etc
with (config.shadowTiddlers) {
SiteUrl = 'http://'+config.tiddlyspotSiteId+'.tiddlyspot.com';
SideBarOptions = SideBarOptions.replace(/(<<saveChanges>>)/,"$1<<tiddler TspotSidebar>>");
OptionsPanel = OptionsPanel.replace(/^/,"<<tiddler TspotOptions>>");
DefaultTiddlers = DefaultTiddlers.replace(/^/,"[[WelcomeToTiddlyspot]] ");
MainMenu = MainMenu.replace(/^/,"[[WelcomeToTiddlyspot]] ");
}
// create some shadow tiddler content
merge(config.shadowTiddlers,{
'TspotOptions':[
"tiddlyspot password:",
"<<option pasUploadPassword>>",
""
].join("\n"),
'TspotControls':[
"| tiddlyspot password:|<<option pasUploadPassword>>|",
"| site management:|<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . . " + config.tiddlyspotSiteId + ">>//(requires tiddlyspot password)//<br>[[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]], [[download (go offline)|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download]]|",
"| links:|[[tiddlyspot.com|http://tiddlyspot.com/]], [[FAQs|http://faq.tiddlyspot.com/]], [[blog|http://tiddlyspot.blogspot.com/]], email [[support|mailto:support@tiddlyspot.com]] & [[feedback|mailto:feedback@tiddlyspot.com]], [[donate|http://tiddlyspot.com/?page=donate]]|"
].join("\n"),
'WelcomeToTiddlyspot':[
"This document is a ~TiddlyWiki from tiddlyspot.com. A ~TiddlyWiki is an electronic notebook that is great for managing todo lists, personal information, and all sorts of things.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //What now?// @@ Before you can save any changes, you need to enter your password in the form below. Then configure privacy and other site settings at your [[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]] (your control panel username is //" + config.tiddlyspotSiteId + "//).",
"<<tiddler TspotControls>>",
"See also GettingStarted.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Working online// @@ You can edit this ~TiddlyWiki right now, and save your changes using the \"save to web\" button in the column on the right.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Working offline// @@ A fully functioning copy of this ~TiddlyWiki can be saved onto your hard drive or USB stick. You can make changes and save them locally without being connected to the Internet. When you're ready to sync up again, just click \"upload\" and your ~TiddlyWiki will be saved back to tiddlyspot.com.",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Help!// @@ Find out more about ~TiddlyWiki at [[TiddlyWiki.com|http://tiddlywiki.com]]. Also visit [[TiddlyWiki.org|http://tiddlywiki.org]] for documentation on learning and using ~TiddlyWiki. New users are especially welcome on the [[TiddlyWiki mailing list|http://groups.google.com/group/TiddlyWiki]], which is an excellent place to ask questions and get help. If you have a tiddlyspot related problem email [[tiddlyspot support|mailto:support@tiddlyspot.com]].",
"",
"@@font-weight:bold;font-size:1.3em;color:#444; //Enjoy :)// @@ We hope you like using your tiddlyspot.com site. Please email [[feedback@tiddlyspot.com|mailto:feedback@tiddlyspot.com]] with any comments or suggestions."
].join("\n"),
'TspotSidebar':[
"<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . . " + config.tiddlyspotSiteId + ">><html><a href='http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download' class='button'>download</a></html>"
].join("\n")
});
//}}}
Cesar just confirmed we will store 10 digit UPC and 14 digit GTIN
Ahmed,
Can you validate with Jacobson they can handle the 10 digit UPC?
Thanks,
Stefan
Stefan Polfliet
Accenture – Kansas City Office
Mobile: <span id="gc-number-7" class="gc-cs-link" title="Call with Google Voice"><span id="gc-number-4" class="gc-cs-link" title="Call with Google Voice">+1 314 591 5203</span></span> / e-mail: stefan.polfliet@accenture.com
From: Valle, Cesar [mailto:cvalle@hostessbrandsllc.com]
Sent: Wednesday, June 12, 2013 12:30 PM
To: Polfliet, Stefan; Ahmed.Sawan@interstatebrands.com; Amit.Rana@interstatebrands.com; Bryant, Mario; dleavitt@hostessbrandsllc.com
Cc: Chintan.Bhavsar@interstatebrands.com; Tuttle, David; Tiwari, Satish; Sheikh, Haroon; Whitt, Byron
Subject: RE: EDI 940 - Feedback From Jacobson
Yes, we will be storing both UPC ang GTIN in SAP
Cesar
________________________________________
From: stefan.polfliet@accenture.com
Sent: Wednesday, June 12, 2013 11:58 AM
To: Ahmed.Sawan@interstatebrands.com; Amit.Rana@interstatebrands.com; Bryant, Mario; dleavitt@hostessbrandsllc.com; Valle, Cesar
Cc: Chintan.Bhavsar@interstatebrands.com; Tuttle, David; satish.tiwari@accenture.com; Sheikh, Haroon; Whitt, Byron
Subject: RE: EDI 940 - Feedback From Jacobson
Mario, David, Cesar,
Can you please clarify one point for us?
We will be storing both GTIN and UPC on our Product master for finished goods.
Historically, we have stored the 10 digit UPC and the 14 digit GTIN.
The product sheet you sent out has a 12 digit UPC.
What UPC will you store on the master data and use going forward? 12 digit or 10 digit?
Thanks,
Stefan
Stefan Polfliet
Accenture – Kansas City Office
Mobile: +1 314 591 5203 / e-mail: stefan.polfliet@accenture.com
From: Sawan, Ahmed [mailto:Ahmed.Sawan@interstatebrands.com]
Sent: Wednesday, June 12, 2013 8:30 AM
To: Polfliet, Stefan; Rana, Amit
Cc: Bhavsar, Chintan; dtuttle@hostessbrandsllc.com; Tiwari, Satish; Sheikh, Haroon; Whitt, Byron
Subject: RE: EDI 940 - Feedback From Jacobson
Hi Stefan and Good morning!
Have you had a chance to consider this issue regarding the master product list?
Jacobson has been bugging me for that list, and in-turn, I have to bug you
Just to recap the issue…
Jacobson needs a master product listing from us containing our product numbers (preferably UPC 12 digit numbers).
This is in lieu of the EDI 888 which won’t be ready till phase 2.
When we send them our EDI 940, the product number that we send them (in the EAN11 field) needs to match up with the numbers in the master product list.
I need to resolve the issue with the EDI 950 product number, and get the master product list to Jacobson in the next few days, so any assistance you can provide would be greatly appreciated.
Thanks, and have a great day!
- Ahmed
From: Sawan, Ahmed
Sent: Monday, June 10, 2013 3:36 PM
To: Polfliet, Stefan; Rana, Amit
Cc: Bhavsar, Chintan; dtuttle@hostessbrandsllc.com; Tiwari, Satish
Subject: RE: EDI 940 - Feedback From Jacobson
Thanks Stefan, for that detailed and prompt response.
I think this addresses most of the issues. I’ll make the necessary changes on my end in the next 30mins.
The only outstanding question that I have has to do with the EAN11 number…
I don’t believe that Jacobson cares if it is a 10 or 12 digit number. They just need it to match up with their product master list.
The product master list that we are planning on sending them contains only the UPC (12 digit) and the GTIN (14 digit) for our products.
I got these numbers from the spreadsheet that you sent me (created by David Leavitt).
Hope this helps,
Ahmed
From: Polfliet, Stefan
Sent: Monday, June 10, 2013 3:17 PM
To: Sawan, Ahmed; Rana, Amit
Cc: Bhavsar, Chintan; dtuttle@hostessbrandsllc.com; Tiwari, Satish
Subject: RE: EDI 940 - Feedback From Jacobson
Importance: High
For the plant code, please take that from the item level: first item in E2EDl24, qualifier = WERKS
• E2EDL44004 – WDATU this is a field representing a time – not a date
• E2EDL24007 – VFDAT this is the shelf life expiration date: will always be blank (or all zeroes) from our side, i.e. we will not determine from which batch they will pick.
Wrt the EAN11: the UPC code that we store = 10 digits, i.e. 5 + 5
Is Jacobson requesting a 12 digit UPC or is this a misunderstanding between SAP and GIS?
From our side, it will always be 10 digits…
Stefan Polfliet
Accenture – Kansas City Office
Mobile: +1 314 591 5203 / e-mail: stefan.polfliet@accenture.com
From: Sawan, Ahmed [mailto:Ahmed.Sawan@interstatebrands.com]
Sent: Monday, June 10, 2013 3:05 PM
To: Rana, Amit
Cc: Bhavsar, Chintan; Polfliet, Stefan; dtuttle@hostessbrandsllc.com; Tiwari, Satish
Subject: RE: EDI 940 - Feedback From Jacobson
Hi Amit/Chintan,
This email is regarding the last EDI 940 test that was sent to us (IDoc 4003 for delivery 80000146 from RD2-160).
Items highlighted in yellow are still open/outstanding issues.
SCAC Code
The SCAC code that you sent in the test file in ZE1EDL20000 - SCACD was "1234" which is not a valid SCAC. Could you populate with a valid SCAC ?
THIS IS RESOLVED
Load Number
The Load Number field (ZE1EDL20000 - EXTI1) was populated with "********************". Please populate with a valid value.
THIS IS RESOLVED
Ship-From Plant Code
The Ship-From Plant Code (E2ADRM1001 - PARTNER_ID where PARTNER_Q qualifier = "OSP") was set to "2008".
This is not a valid plant code assignment for Jacobson. Valid codes are 3200 for Camp Hill, PA or 3100 for Phoenix, AZ.
The SHIP FROM Plant Code is set to 2020. Jacobson is expecting 3200 or 3100. What do we need to do in order to make that happen?
Zero Quantity Line Items
There are line items that contain zero ordered quantity. Any reason why it should be included? If no reason, please exclude.
THIS IS RESOLVED
Invalid Dates
Some of the line items had the value of "00000000" in the following fields:
E2EDL44004 - WDATU
E2EDL24007 - VFDAT
This is not a valid date.
This is still an issue. Both line items in this document had a VFDAT date of "00000000". This is not a valid date.
Invalid SKU numbers at Line Item Level
The item number that was populated in E2EDL24007 - EAN11 are not valid item numbers. This should be populated with a UPC (12 digit) number.
The EAN11 field is supposed to have the UPC number in it.
The line items that we received contained 4500060635 and 4500000509.
Jacobson is expecting the UPC number. What do we need to do in order to correct this issue?
Invalid Line Item Numbers
The test file included PO # "0010000204" with Line Item number "000040" TWICE.
This appeared twice in the 940.
The PO number is in E2EDL24007 - VGBEL. The Line Item number is in the E2EDL24007 - VGPOS.
How can the same line item for the same PO # appear twice on the 940?
THIS IS RESOLVED
Thanks!
- Ahmed
From: Rana, Amit
Sent: Thursday, June 06, 2013 5:09 PM
To: Sawan, Ahmed
Subject: FW: EDI 940 - Feedback From Jacobson
You can use IDOC 4003 for testing to Jacobson
--
Amit Rana
312.285.3325
________________________________________
From: Bhavsar, Chintan
Sent: Thursday, June 06, 2013 4:16 PM
To: Rana, Amit; Sawan, Ahmed; Tiwari, Satish
Cc: Tuttle, David; Polfliet, Stefan
Subject: RE: EDI 940 - Feedback From Jacobson
Created IDoc 4003 for delivery 80000146 from RD2-160.
Thanks & Regards,
Chintan Bhavsar
Desk : 816 - 556 - 5073
Cell : 816 - 839 - 0437
From: Rana, Amit
Sent: Thursday, June 06, 2013 3:27 PM
To: Sawan, Ahmed; Tiwari, Satish; Bhavsar, Chintan
Cc: Tuttle, David; Polfliet, Stefan
Subject: RE: EDI 940 - Feedback From Jacobson
Chintan can you generate IDOC for delivery 80000146?
--
Amit Rana
312.285.3325
________________________________________
From: Sawan, Ahmed
Sent: Thursday, June 06, 2013 3:22 PM
To: Sawan, Ahmed; Rana, Amit; Tiwari, Satish
Cc: Tuttle, David; Polfliet, Stefan
Subject: RE: EDI 940 - Feedback From Jacobson
Gentlemen,
Any updates on the Jacobson EDI 940? Please see email below.
Sorry to keep bugging you, but Jacobson is asking me for status updates, and my management needs status updates as well.
If you have any follow up questions or concerns, lets please discuss them at your earliest convenience.
Thanks!
- Ahmed
From: Sawan, Ahmed
Sent: Tuesday, June 04, 2013 3:32 PM
To: Rana, Amit; Tiwari, Satish
Cc: Tuttle, David; 'Tuttle, David'; Polfliet, Stefan
Subject: RE: EDI 940 - Feedback From Jacobson
Hi Amit/Satish,
Have you had a chance to review this?
I just wanted to follow up to see if you have an update for me.
Thanks for your continued support!
- Ahmed
From: Sawan, Ahmed
Sent: Monday, June 03, 2013 2:43 PM
To: Rana, Amit; Tiwari, Satish
Cc: Tuttle, David; Tuttle, David; Polfliet, Stefan
Subject: EDI 940 - Feedback From Jacobson
Hi Amit and Satish….
As you know, we sent an EDI 940 to Jacobson and were waiting on feedback. We got our feedback today.
Here is a list of the known issues that were identified in the test data that we sent them.
Please review and let us know how you suggest resolving these issues. Your prompt attention to this is greatly appreciated.
Most of these issues are related to the test data that was sent to them. We realize that you were just using dummy/test data which contains invalid numbers, but they are requesting that we start sending them data that is like-production so that they can test it end-to-end through their systems.
SCAC Code
The SCAC code that you sent in the test file in ZE1EDL20000 - SCACD was "1234" which is not a valid SCAC. Could you populate with a valid SCAC ?
Load Number
The Load Number field (ZE1EDL20000 - EXTI1) was populated with "********************". Please populate with a valid value.
Ship-From Plant Code
The Ship-From Plant Code (E2ADRM1001 - PARTNER_ID where PARTNER_Q qualifier = "OSP") was set to "2008".
This is not a valid plant code assignment for Jacobson. Valid codes are 3200 for Camp Hill, PA or 3100 for Phoenix, AZ.
Zero Quantity Line Items
There are line items that contain zero ordered quantity. Any reason why it should be included? If no reason, please exclude.
Invalid Dates
Some of the line items had the value of "00000000" in the following fields:
E2EDL44004 - WDATU
E2EDL24007 - VFDAT
This is not a valid date.
Invalid SKU numbers at Line Item Level
The item number that was populated in E2EDL24007 - EAN11 are not valid item numbers. This should be populated with a UPC (12 digit) number.
If we do not have a UPC number, then we need to populate it with valid Hostess SKU numbers.
Invalid Line Item Numbers
The test file included PO # "0010000204" with Line Item number "000040" TWICE.
This appeared twice in the 940.
The PO number is in E2EDL24007 - VGBEL. The Line Item number is in the E2EDL24007 - VGPOS.
How can the same line item for the same PO # appear twice on the 940?
If you need further clarification about any of these items, please stop by or call me anytime.
I will make myself available at your convenience to assist in any way that I can.
Regards,
Ahmed H Sawan
E-Commerce Consultant
704-293-3068
________________________________________
This message is for the designated recipient only and may contain privileged, proprietary, or otherwise confidential information. If you have received it in error, please notify the sender immediately and delete the original. Any other use of the e-mail by you is prohibited.
Where allowed by local law, electronic communications with Accenture and its affiliates, including e-mail and instant messaging (including content), may be scanned by our systems for the purposes of information security and assessment of internal compliance with Accenture policy.
______________________________________________________________________________________
| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |
| 17/04/2015 11:01:29 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . | ok |
| 17/04/2015 11:27:23 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . | ok |
| 17/04/2015 16:50:46 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . |
| 21/04/2015 17:36:41 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . |
| 22/04/2015 15:21:01 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . | ok |
| 22/04/2015 15:24:53 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . | ok |
| 22/04/2015 15:58:35 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . |
| 23/04/2015 09:19:31 | YourName | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . |
| 28/04/2015 06:34:33 | DavidTuttle | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . |
| 02/05/2015 10:50:44 | DavidTuttle | [[/|http://dlt.tiddlyspot.com/]] | [[store.cgi|http://dlt.tiddlyspot.com/store.cgi]] | . | [[index.html | http://dlt.tiddlyspot.com/index.html]] | . |
/***
|''Name:''|UploadPlugin|
|''Description:''|Save to web a TiddlyWiki|
|''Version:''|4.1.3|
|''Date:''|Feb 24, 2008|
|''Source:''|http://tiddlywiki.bidix.info/#UploadPlugin|
|''Documentation:''|http://tiddlywiki.bidix.info/#UploadPluginDoc|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
|''Requires:''|PasswordOptionPlugin|
***/
//{{{
version.extensions.UploadPlugin = {
major: 4, minor: 1, revision: 3,
date: new Date("Feb 24, 2008"),
source: 'http://tiddlywiki.bidix.info/#UploadPlugin',
author: 'BidiX (BidiX (at) bidix (dot) info',
coreVersion: '2.2.0'
};
//
// Environment
//
if (!window.bidix) window.bidix = {}; // bidix namespace
bidix.debugMode = false; // true to activate both in Plugin and UploadService
//
// Upload Macro
//
config.macros.upload = {
// default values
defaultBackupDir: '', //no backup
defaultStoreScript: "store.php",
defaultToFilename: "index.html",
defaultUploadDir: ".",
authenticateUser: true // UploadService Authenticate User
};
config.macros.upload.label = {
promptOption: "Save and Upload this TiddlyWiki with UploadOptions",
promptParamMacro: "Save and Upload this TiddlyWiki in %0",
saveLabel: "save to web",
saveToDisk: "save to disk",
uploadLabel: "upload"
};
config.macros.upload.messages = {
noStoreUrl: "No store URL in parmeters or options",
usernameOrPasswordMissing: "Username or password missing"
};
config.macros.upload.handler = function(place,macroName,params) {
if (readOnly)
return;
var label;
if (document.location.toString().substr(0,4) == "http")
label = this.label.saveLabel;
else
label = this.label.uploadLabel;
var prompt;
if (params[0]) {
prompt = this.label.promptParamMacro.toString().format([this.destFile(params[0],
(params[1] ? params[1]:bidix.basename(window.location.toString())), params[3])]);
} else {
prompt = this.label.promptOption;
}
createTiddlyButton(place, label, prompt, function() {config.macros.upload.action(params);}, null, null, this.accessKey);
};
config.macros.upload.action = function(params)
{
// for missing macro parameter set value from options
if (!params) params = {};
var storeUrl = params[0] ? params[0] : config.options.txtUploadStoreUrl;
var toFilename = params[1] ? params[1] : config.options.txtUploadFilename;
var backupDir = params[2] ? params[2] : config.options.txtUploadBackupDir;
var uploadDir = params[3] ? params[3] : config.options.txtUploadDir;
var username = params[4] ? params[4] : config.options.txtUploadUserName;
var password = config.options.pasUploadPassword; // for security reason no password as macro parameter
// for still missing parameter set default value
if ((!storeUrl) && (document.location.toString().substr(0,4) == "http"))
storeUrl = bidix.dirname(document.location.toString())+'/'+config.macros.upload.defaultStoreScript;
if (storeUrl.substr(0,4) != "http")
storeUrl = bidix.dirname(document.location.toString()) +'/'+ storeUrl;
if (!toFilename)
toFilename = bidix.basename(window.location.toString());
if (!toFilename)
toFilename = config.macros.upload.defaultToFilename;
if (!uploadDir)
uploadDir = config.macros.upload.defaultUploadDir;
if (!backupDir)
backupDir = config.macros.upload.defaultBackupDir;
// report error if still missing
if (!storeUrl) {
alert(config.macros.upload.messages.noStoreUrl);
clearMessage();
return false;
}
if (config.macros.upload.authenticateUser && (!username || !password)) {
alert(config.macros.upload.messages.usernameOrPasswordMissing);
clearMessage();
return false;
}
bidix.upload.uploadChanges(false,null,storeUrl, toFilename, uploadDir, backupDir, username, password);
return false;
};
config.macros.upload.destFile = function(storeUrl, toFilename, uploadDir)
{
if (!storeUrl)
return null;
var dest = bidix.dirname(storeUrl);
if (uploadDir && uploadDir != '.')
dest = dest + '/' + uploadDir;
dest = dest + '/' + toFilename;
return dest;
};
//
// uploadOptions Macro
//
config.macros.uploadOptions = {
handler: function(place,macroName,params) {
var wizard = new Wizard();
wizard.createWizard(place,this.wizardTitle);
wizard.addStep(this.step1Title,this.step1Html);
var markList = wizard.getElement("markList");
var listWrapper = document.createElement("div");
markList.parentNode.insertBefore(listWrapper,markList);
wizard.setValue("listWrapper",listWrapper);
this.refreshOptions(listWrapper,false);
var uploadCaption;
if (document.location.toString().substr(0,4) == "http")
uploadCaption = config.macros.upload.label.saveLabel;
else
uploadCaption = config.macros.upload.label.uploadLabel;
wizard.setButtons([
{caption: uploadCaption, tooltip: config.macros.upload.label.promptOption,
onClick: config.macros.upload.action},
{caption: this.cancelButton, tooltip: this.cancelButtonPrompt, onClick: this.onCancel}
]);
},
options: [
"txtUploadUserName",
"pasUploadPassword",
"txtUploadStoreUrl",
"txtUploadDir",
"txtUploadFilename",
"txtUploadBackupDir",
"chkUploadLog",
"txtUploadLogMaxLine"
],
refreshOptions: function(listWrapper) {
var opts = [];
for(i=0; i<this.options.length; i++) {
var opt = {};
opts.push();
opt.option = "";
n = this.options[i];
opt.name = n;
opt.lowlight = !config.optionsDesc[n];
opt.description = opt.lowlight ? this.unknownDescription : config.optionsDesc[n];
opts.push(opt);
}
var listview = ListView.create(listWrapper,opts,this.listViewTemplate);
for(n=0; n<opts.length; n++) {
var type = opts[n].name.substr(0,3);
var h = config.macros.option.types[type];
if (h && h.create) {
h.create(opts[n].colElements['option'],type,opts[n].name,opts[n].name,"no");
}
}
},
onCancel: function(e)
{
backstage.switchTab(null);
return false;
},
wizardTitle: "Upload with options",
step1Title: "These options are saved in cookies in your browser",
step1Html: "<input type='hidden' name='markList'></input><br>",
cancelButton: "Cancel",
cancelButtonPrompt: "Cancel prompt",
listViewTemplate: {
columns: [
{name: 'Description', field: 'description', title: "Description", type: 'WikiText'},
{name: 'Option', field: 'option', title: "Option", type: 'String'},
{name: 'Name', field: 'name', title: "Name", type: 'String'}
],
rowClasses: [
{className: 'lowlight', field: 'lowlight'}
]}
};
//
// upload functions
//
if (!bidix.upload) bidix.upload = {};
if (!bidix.upload.messages) bidix.upload.messages = {
//from saving
invalidFileError: "The original file '%0' does not appear to be a valid TiddlyWiki",
backupSaved: "Backup saved",
backupFailed: "Failed to upload backup file",
rssSaved: "RSS feed uploaded",
rssFailed: "Failed to upload RSS feed file",
emptySaved: "Empty template uploaded",
emptyFailed: "Failed to upload empty template file",
mainSaved: "Main TiddlyWiki file uploaded",
mainFailed: "Failed to upload main TiddlyWiki file. Your changes have not been saved",
//specific upload
loadOriginalHttpPostError: "Can't get original file",
aboutToSaveOnHttpPost: 'About to upload on %0 ...',
storePhpNotFound: "The store script '%0' was not found."
};
bidix.upload.uploadChanges = function(onlyIfDirty,tiddlers,storeUrl,toFilename,uploadDir,backupDir,username,password)
{
var callback = function(status,uploadParams,original,url,xhr) {
if (!status) {
displayMessage(bidix.upload.messages.loadOriginalHttpPostError);
return;
}
if (bidix.debugMode)
alert(original.substr(0,500)+"\n...");
// Locate the storeArea div's
var posDiv = locateStoreArea(original);
if((posDiv[0] == -1) || (posDiv[1] == -1)) {
alert(config.messages.invalidFileError.format([localPath]));
return;
}
bidix.upload.uploadRss(uploadParams,original,posDiv);
};
if(onlyIfDirty && !store.isDirty())
return;
clearMessage();
// save on localdisk ?
if (document.location.toString().substr(0,4) == "file") {
var path = document.location.toString();
var localPath = getLocalPath(path);
saveChanges();
}
// get original
var uploadParams = new Array(storeUrl,toFilename,uploadDir,backupDir,username,password);
var originalPath = document.location.toString();
// If url is a directory : add index.html
if (originalPath.charAt(originalPath.length-1) == "/")
originalPath = originalPath + "index.html";
var dest = config.macros.upload.destFile(storeUrl,toFilename,uploadDir);
var log = new bidix.UploadLog();
log.startUpload(storeUrl, dest, uploadDir, backupDir);
displayMessage(bidix.upload.messages.aboutToSaveOnHttpPost.format([dest]));
if (bidix.debugMode)
alert("about to execute Http - GET on "+originalPath);
var r = doHttp("GET",originalPath,null,null,username,password,callback,uploadParams,null);
if (typeof r == "string")
displayMessage(r);
return r;
};
bidix.upload.uploadRss = function(uploadParams,original,posDiv)
{
var callback = function(status,params,responseText,url,xhr) {
if(status) {
var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
displayMessage(bidix.upload.messages.rssSaved,bidix.dirname(url)+'/'+destfile);
bidix.upload.uploadMain(params[0],params[1],params[2]);
} else {
displayMessage(bidix.upload.messages.rssFailed);
}
};
// do uploadRss
if(config.options.chkGenerateAnRssFeed) {
var rssPath = uploadParams[1].substr(0,uploadParams[1].lastIndexOf(".")) + ".xml";
var rssUploadParams = new Array(uploadParams[0],rssPath,uploadParams[2],'',uploadParams[4],uploadParams[5]);
var rssString = generateRss();
// no UnicodeToUTF8 conversion needed when location is "file" !!!
if (document.location.toString().substr(0,4) != "file")
rssString = convertUnicodeToUTF8(rssString);
bidix.upload.httpUpload(rssUploadParams,rssString,callback,Array(uploadParams,original,posDiv));
} else {
bidix.upload.uploadMain(uploadParams,original,posDiv);
}
};
bidix.upload.uploadMain = function(uploadParams,original,posDiv)
{
var callback = function(status,params,responseText,url,xhr) {
var log = new bidix.UploadLog();
if(status) {
// if backupDir specified
if ((params[3]) && (responseText.indexOf("backupfile:") > -1)) {
var backupfile = responseText.substring(responseText.indexOf("backupfile:")+11,responseText.indexOf("\n", responseText.indexOf("backupfile:")));
displayMessage(bidix.upload.messages.backupSaved,bidix.dirname(url)+'/'+backupfile);
}
var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
displayMessage(bidix.upload.messages.mainSaved,bidix.dirname(url)+'/'+destfile);
store.setDirty(false);
log.endUpload("ok");
} else {
alert(bidix.upload.messages.mainFailed);
displayMessage(bidix.upload.messages.mainFailed);
log.endUpload("failed");
}
};
// do uploadMain
var revised = bidix.upload.updateOriginal(original,posDiv);
bidix.upload.httpUpload(uploadParams,revised,callback,uploadParams);
};
bidix.upload.httpUpload = function(uploadParams,data,callback,params)
{
var localCallback = function(status,params,responseText,url,xhr) {
url = (url.indexOf("nocache=") < 0 ? url : url.substring(0,url.indexOf("nocache=")-1));
if (xhr.status == 404)
alert(bidix.upload.messages.storePhpNotFound.format([url]));
if ((bidix.debugMode) || (responseText.indexOf("Debug mode") >= 0 )) {
alert(responseText);
if (responseText.indexOf("Debug mode") >= 0 )
responseText = responseText.substring(responseText.indexOf("\n\n")+2);
} else if (responseText.charAt(0) != '0')
alert(responseText);
if (responseText.charAt(0) != '0')
status = null;
callback(status,params,responseText,url,xhr);
};
// do httpUpload
var boundary = "---------------------------"+"AaB03x";
var uploadFormName = "UploadPlugin";
// compose headers data
var sheader = "";
sheader += "--" + boundary + "\r\nContent-disposition: form-data; name=\"";
sheader += uploadFormName +"\"\r\n\r\n";
sheader += "backupDir="+uploadParams[3] +
";user=" + uploadParams[4] +
";password=" + uploadParams[5] +
";uploaddir=" + uploadParams[2];
if (bidix.debugMode)
sheader += ";debug=1";
sheader += ";;\r\n";
sheader += "\r\n" + "--" + boundary + "\r\n";
sheader += "Content-disposition: form-data; name=\"userfile\"; filename=\""+uploadParams[1]+"\"\r\n";
sheader += "Content-Type: text/html;charset=UTF-8" + "\r\n";
sheader += "Content-Length: " + data.length + "\r\n\r\n";
// compose trailer data
var strailer = new String();
strailer = "\r\n--" + boundary + "--\r\n";
data = sheader + data + strailer;
if (bidix.debugMode) alert("about to execute Http - POST on "+uploadParams[0]+"\n with \n"+data.substr(0,500)+ " ... ");
var r = doHttp("POST",uploadParams[0],data,"multipart/form-data; ;charset=UTF-8; boundary="+boundary,uploadParams[4],uploadParams[5],localCallback,params,null);
if (typeof r == "string")
displayMessage(r);
return r;
};
// same as Saving's updateOriginal but without convertUnicodeToUTF8 calls
bidix.upload.updateOriginal = function(original, posDiv)
{
if (!posDiv)
posDiv = locateStoreArea(original);
if((posDiv[0] == -1) || (posDiv[1] == -1)) {
alert(config.messages.invalidFileError.format([localPath]));
return;
}
var revised = original.substr(0,posDiv[0] + startSaveArea.length) + "\n" +
store.allTiddlersAsHtml() + "\n" +
original.substr(posDiv[1]);
var newSiteTitle = getPageTitle().htmlEncode();
revised = revised.replaceChunk("<title"+">","</title"+">"," " + newSiteTitle + " ");
revised = updateMarkupBlock(revised,"PRE-HEAD","MarkupPreHead");
revised = updateMarkupBlock(revised,"POST-HEAD","MarkupPostHead");
revised = updateMarkupBlock(revised,"PRE-BODY","MarkupPreBody");
revised = updateMarkupBlock(revised,"POST-SCRIPT","MarkupPostBody");
return revised;
};
//
// UploadLog
//
// config.options.chkUploadLog :
// false : no logging
// true : logging
// config.options.txtUploadLogMaxLine :
// -1 : no limit
// 0 : no Log lines but UploadLog is still in place
// n : the last n lines are only kept
// NaN : no limit (-1)
bidix.UploadLog = function() {
if (!config.options.chkUploadLog)
return; // this.tiddler = null
this.tiddler = store.getTiddler("UploadLog");
if (!this.tiddler) {
this.tiddler = new Tiddler();
this.tiddler.title = "UploadLog";
this.tiddler.text = "| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |";
this.tiddler.created = new Date();
this.tiddler.modifier = config.options.txtUserName;
this.tiddler.modified = new Date();
store.addTiddler(this.tiddler);
}
return this;
};
bidix.UploadLog.prototype.addText = function(text) {
if (!this.tiddler)
return;
// retrieve maxLine when we need it
var maxLine = parseInt(config.options.txtUploadLogMaxLine,10);
if (isNaN(maxLine))
maxLine = -1;
// add text
if (maxLine != 0)
this.tiddler.text = this.tiddler.text + text;
// Trunck to maxLine
if (maxLine >= 0) {
var textArray = this.tiddler.text.split('\n');
if (textArray.length > maxLine + 1)
textArray.splice(1,textArray.length-1-maxLine);
this.tiddler.text = textArray.join('\n');
}
// update tiddler fields
this.tiddler.modifier = config.options.txtUserName;
this.tiddler.modified = new Date();
store.addTiddler(this.tiddler);
// refresh and notifiy for immediate update
story.refreshTiddler(this.tiddler.title);
store.notify(this.tiddler.title, true);
};
bidix.UploadLog.prototype.startUpload = function(storeUrl, toFilename, uploadDir, backupDir) {
if (!this.tiddler)
return;
var now = new Date();
var text = "\n| ";
var filename = bidix.basename(document.location.toString());
if (!filename) filename = '/';
text += now.formatString("0DD/0MM/YYYY 0hh:0mm:0ss") +" | ";
text += config.options.txtUserName + " | ";
text += "[["+filename+"|"+location + "]] |";
text += " [[" + bidix.basename(storeUrl) + "|" + storeUrl + "]] | ";
text += uploadDir + " | ";
text += "[[" + bidix.basename(toFilename) + " | " +toFilename + "]] | ";
text += backupDir + " |";
this.addText(text);
};
bidix.UploadLog.prototype.endUpload = function(status) {
if (!this.tiddler)
return;
this.addText(" "+status+" |");
};
//
// Utilities
//
bidix.checkPlugin = function(plugin, major, minor, revision) {
var ext = version.extensions[plugin];
if (!
(ext &&
((ext.major > major) ||
((ext.major == major) && (ext.minor > minor)) ||
((ext.major == major) && (ext.minor == minor) && (ext.revision >= revision))))) {
// write error in PluginManager
if (pluginInfo)
pluginInfo.log.push("Requires " + plugin + " " + major + "." + minor + "." + revision);
eval(plugin); // generate an error : "Error: ReferenceError: xxxx is not defined"
}
};
bidix.dirname = function(filePath) {
if (!filePath)
return;
var lastpos;
if ((lastpos = filePath.lastIndexOf("/")) != -1) {
return filePath.substring(0, lastpos);
} else {
return filePath.substring(0, filePath.lastIndexOf("\\"));
}
};
bidix.basename = function(filePath) {
if (!filePath)
return;
var lastpos;
if ((lastpos = filePath.lastIndexOf("#")) != -1)
filePath = filePath.substring(0, lastpos);
if ((lastpos = filePath.lastIndexOf("/")) != -1) {
return filePath.substring(lastpos + 1);
} else
return filePath.substring(filePath.lastIndexOf("\\")+1);
};
bidix.initOption = function(name,value) {
if (!config.options[name])
config.options[name] = value;
};
//
// Initializations
//
// require PasswordOptionPlugin 1.0.1 or better
bidix.checkPlugin("PasswordOptionPlugin", 1, 0, 1);
// styleSheet
setStylesheet('.txtUploadStoreUrl, .txtUploadBackupDir, .txtUploadDir {width: 22em;}',"uploadPluginStyles");
//optionsDesc
merge(config.optionsDesc,{
txtUploadStoreUrl: "Url of the UploadService script (default: store.php)",
txtUploadFilename: "Filename of the uploaded file (default: in index.html)",
txtUploadDir: "Relative Directory where to store the file (default: . (downloadService directory))",
txtUploadBackupDir: "Relative Directory where to backup the file. If empty no backup. (default: ''(empty))",
txtUploadUserName: "Upload Username",
pasUploadPassword: "Upload Password",
chkUploadLog: "do Logging in UploadLog (default: true)",
txtUploadLogMaxLine: "Maximum of lines in UploadLog (default: 10)"
});
// Options Initializations
bidix.initOption('txtUploadStoreUrl','');
bidix.initOption('txtUploadFilename','');
bidix.initOption('txtUploadDir','');
bidix.initOption('txtUploadBackupDir','');
bidix.initOption('txtUploadUserName','');
bidix.initOption('pasUploadPassword','');
bidix.initOption('chkUploadLog',true);
bidix.initOption('txtUploadLogMaxLine','10');
// Backstage
merge(config.tasks,{
uploadOptions: {text: "upload", tooltip: "Change UploadOptions and Upload", content: '<<uploadOptions>>'}
});
config.backstageTasks.push("uploadOptions");
//}}}
20130618 - Connection still not available
20130618 - Connection unavailable
https://www.evernote.com/shard/s2/nl/117413/0da339d6-e4ac-416a-96ad-56162cb95008/
https://hostessbrandsllc.sharepoint.com/sites/Teams%20Landing/IT/Integration/Shared%20Documents/EDI/Trading%20Partners/Vistar/Vistar%20EDI%20810%20Implementation%20Guide.doc
https://www.evernote.com/shard/s2/nl/117413/e5e47c89-81a4-40f9-9157-adf84ea30245/
https://hostessbrandsllc.sharepoint.com/sites/Teams%20Landing/IT/Integration/Shared%20Documents/EDI/Trading%20Partners/Vistar/Vistar%20EDI%20850%20Implementation%20Guide.DOC
order:2
button:w
buttonLong:waiting for
order:3
button:week
buttonLong:weekly
https://www.evernote.com/shard/s2/sh/745d9e5c-3b3c-49d5-b960-f6fbb1495db5/eaa8c50d85650d143384034aab61ee17
Thanks Kelly for that prompt response.
If you send a BEG 01 with a 01 code at the header level (i.e. cancel entire order), then it doesn’t matter what quantity is in the line items, because the entire order will be cancelled.
Thanks!
- Ahmed
Kelly,
Thank you. That would be perfect!
Haroon/David,
If Acosta wants to delete a line item, they will send us an empty (NULL) value in the PO1 02 (Quantity Ordered) element for that particular line item, in addition to identifying this as a PO Change (BEG 01 = 04).
Our map will know that this line item will need to be deleted and will handle it from there.
Let me know if you have any questions,
Ahmed Sawan
David, I have tested the zero quantity and our system will not send out zero quantity. The outbound test is attached and you will see that the PO1 02 element is empty for item 01001. Our system does let the order release but without the zero.
Please review and let us know how you would like to handle in production.
Thanks. Kel
<<mgtdList title:'Subprojects' startTag:Project tags:'Project && !Complete' view:Project mode:global
where:tiddler.hasParent('Project')
group:Project
gView:bold
newButtonTags:'Project Active'
leftoverTitle:'(Projects that aren't subprojects)
>>
order:6
button:year
buttonLong:yearly
/***
|''Name:''|YourSearchPlugin|
|''Version:''|2.1.3 (2008-04-16)|
|''Source:''|http://tiddlywiki.abego-software.de/#YourSearchPlugin|
|''Author:''|UdoBorkowski (ub [at] abego-software [dot] de)|
|''Licence:''|[[BSD open source license (abego Software)|http://www.abego-software.de/legal/apl-v10.html]]|
|''Copyright:''|© 2005-2008 [[abego Software|http://www.abego-software.de]]|
|''~CoreVersion:''|2.1.0|
|''Community:''|[[del.icio.us|http://del.icio.us/post?url=http://tiddlywiki.abego-software.de/index.html%23YourSearchPlugin]]|
|''Browser:''|Firefox 1.0.4+; Firefox 1.5; ~InternetExplorer 6.0|
!About YourSearch
YourSearch gives you a bunch of new features to simplify and speed up your daily searches in TiddlyWiki. It seamlessly integrates into the standard TiddlyWiki search: just start typing into the 'search' field and explore!
For more information see [[Help|YourSearch Help]].
!Compatibility
This plugin requires TiddlyWiki 2.1.
Check the [[archive|http://tiddlywiki.abego-software.de/archive]] for ~YourSearchPlugins supporting older versions of TiddlyWiki.
!Source Code
***/
/***
This plugin's source code is compressed (and hidden). Use this [[link|http://tiddlywiki.abego-software.de/archive/YourSearchPlugin/Plugin-YourSearch-src.2.1.3.js]] to get the readable source code.
***/
///%
if(!version.extensions.YourSearchPlugin){version.extensions.YourSearchPlugin={major:2,minor:1,revision:3,source:"http://tiddlywiki.abego-software.de/#YourSearchPlugin",licence:"[[BSD open source license (abego Software)|http://www.abego-software.de/legal/apl-v10.html]]",copyright:"Copyright (c) abego Software GmbH, 2005-2008 (www.abego-software.de)"};if(!window.abego){window.abego={};}
if(!Array.forEach){Array.forEach=function(_1,_2,_3){for(var i=0,len=_1.length;i<len;i++){_2.call(_3,_1[i],i,_1);}};Array.prototype.forEach=function(_5,_6){for(var i=0,len=this.length;i<len;i++){_5.call(_6,this[i],i,this);}};}
abego.toInt=function(s,_9){if(!s){return _9;}
var n=parseInt(s);return(n==NaN)?_9:n;};abego.createEllipsis=function(_b){var e=createTiddlyElement(_b,"span");e.innerHTML="…";};abego.shallowCopy=function(_d){if(!_d){return _d;}
var _e={};for(var n in _d){_e[n]=_d[n];}
return _e;};abego.copyOptions=function(_10){return!_10?{}:abego.shallowCopy(_10);};abego.countStrings=function(_11,s){if(!s){return 0;}
var len=s.length;var n=0;var _15=0;while(1){var i=_11.indexOf(s,_15);if(i<0){return n;}
n++;_15=i+len;}
return n;};abego.getBracedText=function(_17,_18,_19){if(!_18){_18=0;}
var re=/\{([^\}]*)\}/gm;re.lastIndex=_18;var m=re.exec(_17);if(m){var s=m[1];var _1d=abego.countStrings(s,"{");if(!_1d){if(_19){_19.lastIndex=re.lastIndex;}
return s;}
var len=_17.length;for(var i=re.lastIndex;i<len&&_1d;i++){var c=_17.charAt(i);if(c=="{"){_1d++;}else{if(c=="}"){_1d--;}}}
if(!_1d){if(_19){_19.lastIndex=i-1;}
return _17.substring(m.index+1,i-1);}}};abego.select=function(_21,_22,_23,_24){if(!_24){_24=[];}
_21.forEach(function(t){if(_22.call(_23,t)){_24.push(t);}});return _24;};abego.consumeEvent=function(e){if(e.stopPropagation){e.stopPropagation();}
if(e.preventDefault){e.preventDefault();}
e.cancelBubble=true;e.returnValue=true;};abego.TiddlerFilterTerm=function(_27,_28){if(!_28){_28={};}
var _29=_27;if(!_28.textIsRegExp){_29=_27.escapeRegExp();if(_28.fullWordMatch){_29="\\b"+_29+"\\b";}}
var _2a=new RegExp(_29,"m"+(_28.caseSensitive?"":"i"));this.tester=new abego.MultiFieldRegExpTester(_2a,_28.fields,_28.withExtendedFields);};abego.TiddlerFilterTerm.prototype.test=function(_2b){return this.tester.test(_2b);};abego.parseNewTiddlerCommandLine=function(s){var m=/(.*?)\.(?:\s+|$)([^#]*)(#.*)?/.exec(s);if(!m){m=/([^#]*)()(#.*)?/.exec(s);}
if(m){var r;if(m[3]){var s2=m[3].replace(/#/g,"");r=s2.parseParams("tag");}else{r=[[]];}
var _30=m[2]?m[2].trim():"";r.push({name:"text",value:_30});r[0].text=[_30];return{title:m[1].trim(),params:r};}else{return{title:s.trim(),params:[[]]};}};abego.parseTiddlerFilterTerm=function(_31,_32,_33){var re=/\s*(?:(?:\{([^\}]*)\})|(?:(=)|([#%!])|(?:(\w+)\s*\:(?!\/\/))|(?:(?:("(?:(?:\\")|[^"])+")|(?:\/((?:(?:\\\/)|[^\/])+)\/)|(\w+\:\/\/[^\s]+)|([^\s\)\-\"]+)))))/mg;var _35={"!":"title","%":"text","#":"tags"};var _36={};var _37;re.lastIndex=_32;while(1){var i=re.lastIndex;var m=re.exec(_31);if(!m||m.index!=i){throw"Word or String literal expected";}
if(m[1]){var _3a={};var _3b=abego.getBracedText(_31,0,_3a);if(!_3b){throw"Invalid {...} syntax";}
var f=Function("tiddler","return ("+_3b+");");return{func:f,lastIndex:_3a.lastIndex,markRE:null};}
if(m[2]){_37=true;}else{if(m[3]){_36[_35[m[3]]]=1;}else{if(m[4]){_36[m[4]]=1;}else{var _3d=m[6];var _3e=m[5]?window.eval(m[5]):m[6]?m[6]:m[7]?m[7]:m[8];var _33=abego.copyOptions(_33);_33.fullWordMatch=_37;_33.textIsRegExp=_3d;var _3f=[];for(var n in _36){_3f.push(n);}
if(_3f.length==0){_33.fields=_33.defaultFields;}else{_33.fields=_3f;_33.withExtendedFields=false;}
var _41=new abego.TiddlerFilterTerm(_3e,_33);var _42=_3d?_3e:_3e.escapeRegExp();if(_42&&_37){_42="\\b"+_42+"\\b";}
return{func:function(_43){return _41.test(_43);},lastIndex:re.lastIndex,markRE:_42?"(?:"+_42+")":null};}}}}};abego.BoolExp=function(s,_45,_46){this.s=s;var _47=_46&&_46.defaultOperationIs_OR;var _48=/\s*(?:(\-|not)|(\())/gi;var _49=/\s*\)/g;var _4a=/\s*(?:(and|\&\&)|(or|\|\|))/gi;var _4b=/\s*[^\)\s]/g;var _4c=/\s*(\-|not)?(\s*\()?/gi;var _4d;var _4e=function(_4f){_4c.lastIndex=_4f;var m=_4c.exec(s);var _51;var _52;if(m&&m.index==_4f){_4f+=m[0].length;_51=m[1];if(m[2]){var e=_4d(_4f);_49.lastIndex=e.lastIndex;if(!_49.exec(s)){throw"Missing ')'";}
_52={func:e.func,lastIndex:_49.lastIndex,markRE:e.markRE};}}
if(!_52){_52=_45(s,_4f,_46);}
if(_51){_52.func=(function(f){return function(_55){return!f(_55);};})(_52.func);_52.markRE=null;}
return _52;};_4d=function(_56){var _57=_4e(_56);while(1){var l=_57.lastIndex;_4a.lastIndex=l;var m=_4a.exec(s);var _5a;var _5b;if(m&&m.index==l){_5a=!m[1];_5b=_4e(_4a.lastIndex);}else{try{_5b=_4e(l);}
catch(e){return _57;}
_5a=_47;}
_57.func=(function(_5c,_5d,_5e){return _5e?function(_5f){return _5c(_5f)||_5d(_5f);}:function(_60){return _5c(_60)&&_5d(_60);};})(_57.func,_5b.func,_5a);_57.lastIndex=_5b.lastIndex;if(!_57.markRE){_57.markRE=_5b.markRE;}else{if(_5b.markRE){_57.markRE=_57.markRE+"|"+_5b.markRE;}}}};var _61=_4d(0);this.evalFunc=_61.func;if(_61.markRE){this.markRegExp=new RegExp(_61.markRE,_46.caseSensitive?"mg":"img");}};abego.BoolExp.prototype.exec=function(){return this.evalFunc.apply(this,arguments);};abego.BoolExp.prototype.getMarkRegExp=function(){return this.markRegExp;};abego.BoolExp.prototype.toString=function(){return this.s;};abego.MultiFieldRegExpTester=function(re,_63,_64){this.re=re;this.fields=_63?_63:["title","text","tags"];this.withExtendedFields=_64;};abego.MultiFieldRegExpTester.prototype.test=function(_65){var re=this.re;for(var i=0;i<this.fields.length;i++){var s=store.getValue(_65,this.fields[i]);if(typeof s=="string"&&re.test(s)){return this.fields[i];}}
if(this.withExtendedFields){return store.forEachField(_65,function(_69,_6a,_6b){return typeof _6b=="string"&&re.test(_6b)?_6a:null;},true);}
return null;};abego.TiddlerQuery=function(_6c,_6d,_6e,_6f,_70){if(_6e){this.regExp=new RegExp(_6c,_6d?"mg":"img");this.tester=new abego.MultiFieldRegExpTester(this.regExp,_6f,_70);}else{this.expr=new abego.BoolExp(_6c,abego.parseTiddlerFilterTerm,{defaultFields:_6f,caseSensitive:_6d,withExtendedFields:_70});}
this.getQueryText=function(){return _6c;};this.getUseRegExp=function(){return _6e;};this.getCaseSensitive=function(){return _6d;};this.getDefaultFields=function(){return _6f;};this.getWithExtendedFields=function(){return _70;};};abego.TiddlerQuery.prototype.test=function(_71){if(!_71){return false;}
if(this.regExp){return this.tester.test(_71);}
return this.expr.exec(_71);};abego.TiddlerQuery.prototype.filter=function(_72){return abego.select(_72,this.test,this);};abego.TiddlerQuery.prototype.getMarkRegExp=function(){if(this.regExp){return"".search(this.regExp)>=0?null:this.regExp;}
return this.expr.getMarkRegExp();};abego.TiddlerQuery.prototype.toString=function(){return(this.regExp?this.regExp:this.expr).toString();};abego.PageWiseRenderer=function(){this.firstIndexOnPage=0;};merge(abego.PageWiseRenderer.prototype,{setItems:function(_73){this.items=_73;this.setFirstIndexOnPage(0);},getMaxPagesInNavigation:function(){return 10;},getItemsCount:function(_74){return this.items?this.items.length:0;},getCurrentPageIndex:function(){return Math.floor(this.firstIndexOnPage/this.getItemsPerPage());},getLastPageIndex:function(){return Math.floor((this.getItemsCount()-1)/this.getItemsPerPage());},setFirstIndexOnPage:function(_75){this.firstIndexOnPage=Math.min(Math.max(0,_75),this.getItemsCount()-1);},getFirstIndexOnPage:function(){this.firstIndexOnPage=Math.floor(this.firstIndexOnPage/this.getItemsPerPage())*this.getItemsPerPage();return this.firstIndexOnPage;},getLastIndexOnPage:function(){return Math.min(this.getFirstIndexOnPage()+this.getItemsPerPage()-1,this.getItemsCount()-1);},onPageChanged:function(_76,_77){},renderPage:function(_78){if(_78.beginRendering){_78.beginRendering(this);}
try{if(this.getItemsCount()){var _79=this.getLastIndexOnPage();var _7a=-1;for(var i=this.getFirstIndexOnPage();i<=_79;i++){_7a++;_78.render(this,this.items[i],i,_7a);}}}
finally{if(_78.endRendering){_78.endRendering(this);}}},addPageNavigation:function(_7c){if(!this.getItemsCount()){return;}
var _7d=this;var _7e=function(e){if(!e){var e=window.event;}
abego.consumeEvent(e);var _80=abego.toInt(this.getAttribute("page"),0);var _81=_7d.getCurrentPageIndex();if(_80==_81){return;}
var _82=_80*_7d.getItemsPerPage();_7d.setFirstIndexOnPage(_82);_7d.onPageChanged(_80,_81);};var _83;var _84=this.getCurrentPageIndex();var _85=this.getLastPageIndex();if(_84>0){_83=createTiddlyButton(_7c,"Previous","Go to previous page (Shortcut: Alt-'<')",_7e,"prev");_83.setAttribute("page",(_84-1).toString());_83.setAttribute("accessKey","<");}
for(var i=-this.getMaxPagesInNavigation();i<this.getMaxPagesInNavigation();i++){var _87=_84+i;if(_87<0){continue;}
if(_87>_85){break;}
var _88=(i+_84+1).toString();var _89=_87==_84?"currentPage":"otherPage";_83=createTiddlyButton(_7c,_88,"Go to page %0".format([_88]),_7e,_89);_83.setAttribute("page",(_87).toString());}
if(_84<_85){_83=createTiddlyButton(_7c,"Next","Go to next page (Shortcut: Alt-'>')",_7e,"next");_83.setAttribute("page",(_84+1).toString());_83.setAttribute("accessKey",">");}}});abego.LimitedTextRenderer=function(){var _8a=40;var _8b=4;var _8c=function(_8d,_8e,_8f){var n=_8d.length;if(n==0){_8d.push({start:_8e,end:_8f});return;}
var i=0;for(;i<n;i++){var _92=_8d[i];if(_92.start<=_8f&&_8e<=_92.end){var r;var _94=i+1;for(;_94<n;_94++){r=_8d[_94];if(r.start>_8f||_8e>_92.end){break;}}
var _95=_8e;var _96=_8f;for(var j=i;j<_94;j++){r=_8d[j];_95=Math.min(_95,r.start);_96=Math.max(_96,r.end);}
_8d.splice(i,_94-i,{start:_95,end:_96});return;}
if(_92.start>_8f){break;}}
_8d.splice(i,0,{start:_8e,end:_8f});};var _98=function(_99){var _9a=0;for(var i=0;i<_99.length;i++){var _9c=_99[i];_9a+=_9c.end-_9c.start;}
return _9a;};var _9d=function(c){return(c>="a"&&c<="z")||(c>="A"&&c<="Z")||c=="_";};var _9f=function(s,_a1){if(!_9d(s[_a1])){return null;}
for(var i=_a1-1;i>=0&&_9d(s[i]);i--){}
var _a3=i+1;var n=s.length;for(i=_a1+1;i<n&&_9d(s[i]);i++){}
return{start:_a3,end:i};};var _a5=function(s,_a7,_a8){var _a9;if(_a8){_a9=_9f(s,_a7);}else{if(_a7<=0){return _a7;}
_a9=_9f(s,_a7-1);}
if(!_a9){return _a7;}
if(_a8){if(_a9.start>=_a7-_8b){return _a9.start;}
if(_a9.end<=_a7+_8b){return _a9.end;}}else{if(_a9.end<=_a7+_8b){return _a9.end;}
if(_a9.start>=_a7-_8b){return _a9.start;}}
return _a7;};var _aa=function(s,_ac){var _ad=[];if(_ac){var _ae=0;var n=s.length;var _b0=0;do{_ac.lastIndex=_ae;var _b1=_ac.exec(s);if(_b1){if(_ae<_b1.index){var t=s.substring(_ae,_b1.index);_ad.push({text:t});}
_ad.push({text:_b1[0],isMatch:true});_ae=_b1.index+_b1[0].length;}else{_ad.push({text:s.substr(_ae)});break;}}while(true);}else{_ad.push({text:s});}
return _ad;};var _b3=function(_b4){var _b5=0;for(var i=0;i<_b4.length;i++){if(_b4[i].isMatch){_b5++;}}
return _b5;};var _b7=function(s,_b9,_ba,_bb,_bc){var _bd=Math.max(Math.floor(_bc/(_bb+1)),_8a);var _be=Math.max(_bd-(_ba-_b9),0);var _bf=Math.min(Math.floor(_ba+_be/3),s.length);var _c0=Math.max(_bf-_bd,0);_c0=_a5(s,_c0,true);_bf=_a5(s,_bf,false);return{start:_c0,end:_bf};};var _c1=function(_c2,s,_c4){var _c5=[];var _c6=_b3(_c2);var pos=0;for(var i=0;i<_c2.length;i++){var t=_c2[i];var _ca=t.text;if(t.isMatch){var _cb=_b7(s,pos,pos+_ca.length,_c6,_c4);_8c(_c5,_cb.start,_cb.end);}
pos+=_ca.length;}
return _c5;};var _cc=function(s,_ce,_cf){var _d0=_cf-_98(_ce);while(_d0>0){if(_ce.length==0){_8c(_ce,0,_a5(s,_cf,false));return;}else{var _d1=_ce[0];var _d2;var _d3;if(_d1.start==0){_d2=_d1.end;if(_ce.length>1){_d3=_ce[1].start;}else{_8c(_ce,_d2,_a5(s,_d2+_d0,false));return;}}else{_d2=0;_d3=_d1.start;}
var _d4=Math.min(_d3,_d2+_d0);_8c(_ce,_d2,_d4);_d0-=(_d4-_d2);}}};var _d5=function(_d6,s,_d8,_d9,_da){if(_d9.length==0){return;}
var _db=function(_dc,s,_de,_df,_e0){var t;var _e2;var pos=0;var i=0;var _e5=0;for(;i<_de.length;i++){t=_de[i];_e2=t.text;if(_df<pos+_e2.length){_e5=_df-pos;break;}
pos+=_e2.length;}
var _e6=_e0-_df;for(;i<_de.length&&_e6>0;i++){t=_de[i];_e2=t.text.substr(_e5);_e5=0;if(_e2.length>_e6){_e2=_e2.substr(0,_e6);}
if(t.isMatch){createTiddlyElement(_dc,"span",null,"marked",_e2);}else{createTiddlyText(_dc,_e2);}
_e6-=_e2.length;}
if(_e0<s.length){abego.createEllipsis(_dc);}};if(_d9[0].start>0){abego.createEllipsis(_d6);}
var _e7=_da;for(var i=0;i<_d9.length&&_e7>0;i++){var _e9=_d9[i];var len=Math.min(_e9.end-_e9.start,_e7);_db(_d6,s,_d8,_e9.start,_e9.start+len);_e7-=len;}};this.render=function(_eb,s,_ed,_ee){if(s.length<_ed){_ed=s.length;}
var _ef=_aa(s,_ee);var _f0=_c1(_ef,s,_ed);_cc(s,_f0,_ed);_d5(_eb,s,_ef,_f0,_ed);};};(function(){function alertAndThrow(msg){alert(msg);throw msg;}
if(version.major<2||(version.major==2&&version.minor<1)){alertAndThrow("YourSearchPlugin requires TiddlyWiki 2.1 or newer.\n\nCheck the archive for YourSearch plugins\nsupporting older versions of TiddlyWiki.\n\nArchive: http://tiddlywiki.abego-software.de/archive");}
abego.YourSearch={};var _f2;var _f3;var _f4=function(_f5){_f2=_f5;};var _f6=function(){return _f2?_f2:[];};var _f7=function(){return _f2?_f2.length:0;};var _f8=4;var _f9=10;var _fa=2;var _fb=function(s,re){var m=s.match(re);return m?m.length:0;};var _ff=function(_100,_101){var _102=_101.getMarkRegExp();if(!_102){return 1;}
var _103=_100.title.match(_102);var _104=_103?_103.length:0;var _105=_fb(_100.getTags(),_102);var _106=_103?_103.join("").length:0;var _107=_100.title.length>0?_106/_100.title.length:0;var rank=_104*_f8+_105*_fa+_107*_f9+1;return rank;};var _109=function(_10a,_10b,_10c,_10d,_10e,_10f){_f3=null;var _110=_10a.reverseLookup("tags",_10f,false);try{var _111=[];if(config.options.chkSearchInTitle){_111.push("title");}
if(config.options.chkSearchInText){_111.push("text");}
if(config.options.chkSearchInTags){_111.push("tags");}
_f3=new abego.TiddlerQuery(_10b,_10c,_10d,_111,config.options.chkSearchExtendedFields);}
catch(e){return[];}
var _112=_f3.filter(_110);var _113=abego.YourSearch.getRankFunction();for(var i=0;i<_112.length;i++){var _115=_112[i];var rank=_113(_115,_f3);_115.searchRank=rank;}
if(!_10e){_10e="title";}
var _117=function(a,b){var _11a=a.searchRank-b.searchRank;if(_11a==0){if(a[_10e]==b[_10e]){return(0);}else{return(a[_10e]<b[_10e])?-1:+1;}}else{return(_11a>0)?-1:+1;}};_112.sort(_117);return _112;};var _11b=80;var _11c=50;var _11d=250;var _11e=50;var _11f=25;var _120=10;var _121="yourSearchResult";var _122="yourSearchResultItems";var _123;var _124;var _125;var _126;var _127;var _128=function(){if(version.extensions.YourSearchPlugin.styleSheetInited){return;}
version.extensions.YourSearchPlugin.styleSheetInited=true;setStylesheet(store.getTiddlerText("YourSearchStyleSheet"),"yourSearch");};var _129=function(){return _124!=null&&_124.parentNode==document.body;};var _12a=function(){if(_129()){document.body.removeChild(_124);}};var _12b=function(e){_12a();var _12d=this.getAttribute("tiddlyLink");if(_12d){var _12e=this.getAttribute("withHilite");var _12f=highlightHack;if(_12e&&_12e=="true"&&_f3){highlightHack=_f3.getMarkRegExp();}
story.displayTiddler(this,_12d);highlightHack=_12f;}
return(false);};var _130=function(){if(!_125){return;}
var root=_125;var _132=findPosX(root);var _133=findPosY(root);var _134=root.offsetHeight;var _135=_132;var _136=_133+_134;var _137=findWindowWidth();if(_137<_124.offsetWidth){_124.style.width=(_137-100)+"px";_137=findWindowWidth();}
var _138=_124.offsetWidth;if(_135+_138>_137){_135=_137-_138-30;}
if(_135<0){_135=0;}
_124.style.left=_135+"px";_124.style.top=_136+"px";_124.style.display="block";};var _139=function(){if(_124){window.scrollTo(0,ensureVisible(_124));}
if(_125){window.scrollTo(0,ensureVisible(_125));}};var _13a=function(){_130();_139();};var _13b;var _13c;var _13d=new abego.PageWiseRenderer();var _13e=function(_13f){this.itemHtml=store.getTiddlerText("YourSearchItemTemplate");if(!this.itemHtml){alertAndThrow("YourSearchItemTemplate not found");}
this.place=document.getElementById(_122);if(!this.place){this.place=createTiddlyElement(_13f,"div",_122);}};merge(_13e.prototype,{render:function(_140,_141,_142,_143){_13b=_143;_13c=_141;var item=createTiddlyElement(this.place,"div",null,"yourSearchItem");item.innerHTML=this.itemHtml;applyHtmlMacros(item,null);refreshElements(item,null);},endRendering:function(_145){_13c=null;}});var _146=function(){if(!_124||!_125){return;}
var html=store.getTiddlerText("YourSearchResultTemplate");if(!html){html="<b>Tiddler YourSearchResultTemplate not found</b>";}
_124.innerHTML=html;applyHtmlMacros(_124,null);refreshElements(_124,null);var _148=new _13e(_124);_13d.renderPage(_148);_13a();};_13d.getItemsPerPage=function(){var n=(config.options.chkPreviewText)?abego.toInt(config.options.txtItemsPerPageWithPreview,_120):abego.toInt(config.options.txtItemsPerPage,_11f);return(n>0)?n:1;};_13d.onPageChanged=function(){_146();};var _14a=function(){if(_125==null||!config.options.chkUseYourSearch){return;}
if((_125.value==_123)&&_123&&!_129()){if(_124&&(_124.parentNode!=document.body)){document.body.appendChild(_124);_13a();}else{abego.YourSearch.onShowResult(true);}}};var _14b=function(){_12a();_124=null;_123=null;};var _14c=function(self,e){while(e!=null){if(self==e){return true;}
e=e.parentNode;}
return false;};var _14f=function(e){if(e.target==_125){return;}
if(e.target==_126){return;}
if(_124&&_14c(_124,e.target)){return;}
_12a();};var _151=function(e){if(e.keyCode==27){_12a();}};addEvent(document,"click",_14f);addEvent(document,"keyup",_151);var _153=function(text,_155,_156){_123=text;_f4(_109(store,text,_155,_156,"title","excludeSearch"));abego.YourSearch.onShowResult();};var _157=function(_158,_159,_15a,_15b,_15c,_15d){_128();_123="";var _15e=null;var _15f=function(txt){if(config.options.chkUseYourSearch){_153(txt.value,config.options.chkCaseSensitiveSearch,config.options.chkRegExpSearch);}else{story.search(txt.value,config.options.chkCaseSensitiveSearch,config.options.chkRegExpSearch);}
_123=txt.value;};var _161=function(e){_15f(_125);return false;};var _163=function(e){if(!e){var e=window.event;}
_125=this;switch(e.keyCode){case 13:if(e.ctrlKey&&_127&&_129()){_127.onclick.apply(_127,[e]);}else{_15f(this);}
break;case 27:if(_129()){_12a();}else{this.value="";clearMessage();}
break;}
if(String.fromCharCode(e.keyCode)==this.accessKey||e.altKey){_14a();}
if(this.value.length<3&&_15e){clearTimeout(_15e);}
if(this.value.length>2){if(this.value!=_123){if(!config.options.chkUseYourSearch||config.options.chkSearchAsYouType){if(_15e){clearTimeout(_15e);}
var txt=this;_15e=setTimeout(function(){_15f(txt);},500);}}else{if(_15e){clearTimeout(_15e);}}}
if(this.value.length==0){_12a();}};var _166=function(e){this.select();clearMessage();_14a();};var args=_15c.parseParams("list",null,true);var _169=getFlag(args,"buttonAtRight");var _16a=getParam(args,"sizeTextbox",this.sizeTextbox);var btn;if(!_169){btn=createTiddlyButton(_158,this.label,this.prompt,_161);}
var txt=createTiddlyElement(_158,"input",null,null,null);if(_15a[0]){txt.value=_15a[0];}
txt.onkeyup=_163;txt.onfocus=_166;txt.setAttribute("size",_16a);txt.setAttribute("accessKey",this.accessKey);txt.setAttribute("autocomplete","off");if(config.browser.isSafari){txt.setAttribute("type","search");txt.setAttribute("results","5");}else{txt.setAttribute("type","text");}
if(_169){btn=createTiddlyButton(_158,this.label,this.prompt,_161);}
_125=txt;_126=btn;};var _16d=function(){_12a();var _16e=_f6();var n=_16e.length;if(n){var _170=[];for(var i=0;i<n;i++){_170.push(_16e[i].title);}
story.displayTiddlers(null,_170);}};var _172=function(_173,_174,_175,_176){invokeMacro(_173,"option",_174,_175,_176);var elem=_173.lastChild;var _178=elem.onclick;elem.onclick=function(e){var _17a=_178.apply(this,arguments);_146();return _17a;};return elem;};var _17b=function(s){var _17d=["''","{{{","}}}","//","<<<","/***","***/"];var _17e="";for(var i=0;i<_17d.length;i++){if(i!=0){_17e+="|";}
_17e+="("+_17d[i].escapeRegExp()+")";}
return s.replace(new RegExp(_17e,"mg"),"").trim();};var _180=function(){var i=_13b;return(i>=0&&i<=9)?(i<9?(i+1):0):-1;};var _182=new abego.LimitedTextRenderer();var _183=function(_184,s,_186){_182.render(_184,s,_186,_f3.getMarkRegExp());};var _187=TiddlyWiki.prototype.saveTiddler;TiddlyWiki.prototype.saveTiddler=function(_188,_189,_18a,_18b,_18c,tags,_18e){_187.apply(this,arguments);_14b();};var _18f=TiddlyWiki.prototype.removeTiddler;TiddlyWiki.prototype.removeTiddler=function(_190){_18f.apply(this,arguments);_14b();};config.macros.yourSearch={label:"yourSearch",prompt:"Gives access to the current/last YourSearch result",handler:function(_191,_192,_193,_194,_195,_196){if(_193.length==0){return;}
var name=_193[0];var func=config.macros.yourSearch.funcs[name];if(func){func(_191,_192,_193,_194,_195,_196);}},tests:{"true":function(){return true;},"false":function(){return false;},"found":function(){return _f7()>0;},"previewText":function(){return config.options.chkPreviewText;}},funcs:{itemRange:function(_199){if(_f7()){var _19a=_13d.getLastIndexOnPage();var s="%0 - %1".format([_13d.getFirstIndexOnPage()+1,_19a+1]);createTiddlyText(_199,s);}},count:function(_19c){createTiddlyText(_19c,_f7().toString());},query:function(_19d){if(_f3){createTiddlyText(_19d,_f3.toString());}},version:function(_19e){var t="YourSearch %0.%1.%2".format([version.extensions.YourSearchPlugin.major,version.extensions.YourSearchPlugin.minor,version.extensions.YourSearchPlugin.revision]);var e=createTiddlyElement(_19e,"a");e.setAttribute("href","http://tiddlywiki.abego-software.de/#YourSearchPlugin");e.innerHTML="<font color=\"black\" face=\"Arial, Helvetica, sans-serif\">"+t+"<font>";},copyright:function(_1a1){var e=createTiddlyElement(_1a1,"a");e.setAttribute("href","http://www.abego-software.de");e.innerHTML="<font color=\"black\" face=\"Arial, Helvetica, sans-serif\">© 2005-2008 <b><font color=\"red\">abego</font></b> Software<font>";},newTiddlerButton:function(_1a3){if(_f3){var r=abego.parseNewTiddlerCommandLine(_f3.getQueryText());var btn=config.macros.newTiddler.createNewTiddlerButton(_1a3,r.title,r.params,"new tiddler","Create a new tiddler based on search text. (Shortcut: Ctrl-Enter; Separators: '.', '#')",null,"text");var _1a6=btn.onclick;btn.onclick=function(){_12a();_1a6.apply(this,arguments);};_127=btn;}},linkButton:function(_1a7,_1a8,_1a9,_1aa,_1ab,_1ac){if(_1a9<2){return;}
var _1ad=_1a9[1];var text=_1a9<3?_1ad:_1a9[2];var _1af=_1a9<4?text:_1a9[3];var _1b0=_1a9<5?null:_1a9[4];var btn=createTiddlyButton(_1a7,text,_1af,_12b,null,null,_1b0);btn.setAttribute("tiddlyLink",_1ad);},closeButton:function(_1b2,_1b3,_1b4,_1b5,_1b6,_1b7){var _1b8=createTiddlyButton(_1b2,"close","Close the Search Results (Shortcut: ESC)",_12a);},openAllButton:function(_1b9,_1ba,_1bb,_1bc,_1bd,_1be){var n=_f7();if(n==0){return;}
var _1c0=n==1?"open tiddler":"open all %0 tiddlers".format([n]);var _1c1=createTiddlyButton(_1b9,_1c0,"Open all found tiddlers (Shortcut: Alt-O)",_16d);_1c1.setAttribute("accessKey","O");},naviBar:function(_1c2,_1c3,_1c4,_1c5,_1c6,_1c7){_13d.addPageNavigation(_1c2);},"if":function(_1c8,_1c9,_1ca,_1cb,_1cc,_1cd){if(_1ca.length<2){return;}
var _1ce=_1ca[1];var _1cf=(_1ce=="not");if(_1cf){if(_1ca.length<3){return;}
_1ce=_1ca[2];}
var test=config.macros.yourSearch.tests[_1ce];var _1d1=false;try{if(test){_1d1=test(_1c8,_1c9,_1ca,_1cb,_1cc,_1cd)!=_1cf;}else{_1d1=(!eval(_1ce))==_1cf;}}
catch(ex){}
if(!_1d1){_1c8.style.display="none";}},chkPreviewText:function(_1d2,_1d3,_1d4,_1d5,_1d6,_1d7){var _1d8=_1d4.slice(1).join(" ");var elem=_172(_1d2,"chkPreviewText",_1d5,_1d7);elem.setAttribute("accessKey","P");elem.title="Show text preview of found tiddlers (Shortcut: Alt-P)";return elem;}}};config.macros.foundTiddler={label:"foundTiddler",prompt:"Provides information on the tiddler currently processed on the YourSearch result page",handler:function(_1da,_1db,_1dc,_1dd,_1de,_1df){var name=_1dc[0];var func=config.macros.foundTiddler.funcs[name];if(func){func(_1da,_1db,_1dc,_1dd,_1de,_1df);}},funcs:{title:function(_1e2,_1e3,_1e4,_1e5,_1e6,_1e7){if(!_13c){return;}
var _1e8=_180();var _1e9=_1e8>=0?"Open tiddler (Shortcut: Alt-%0)".format([_1e8.toString()]):"Open tiddler";var btn=createTiddlyButton(_1e2,null,_1e9,_12b,null);btn.setAttribute("tiddlyLink",_13c.title);btn.setAttribute("withHilite","true");_183(btn,_13c.title,_11b);if(_1e8>=0){btn.setAttribute("accessKey",_1e8.toString());}},tags:function(_1eb,_1ec,_1ed,_1ee,_1ef,_1f0){if(!_13c){return;}
_183(_1eb,_13c.getTags(),_11c);},text:function(_1f1,_1f2,_1f3,_1f4,_1f5,_1f6){if(!_13c){return;}
_183(_1f1,_17b(_13c.text),_11d);},field:function(_1f7,_1f8,_1f9,_1fa,_1fb,_1fc){if(!_13c){return;}
var name=_1f9[1];var len=_1f9.length>2?abego.toInt(_1f9[2],_11e):_11e;var v=store.getValue(_13c,name);if(v){_183(_1f7,_17b(v),len);}},number:function(_200,_201,_202,_203,_204,_205){var _206=_180();if(_206>=0){var text="%0)".format([_206.toString()]);createTiddlyElement(_200,"span",null,"shortcutNumber",text);}}}};var opts={chkUseYourSearch:true,chkPreviewText:true,chkSearchAsYouType:true,chkSearchInTitle:true,chkSearchInText:true,chkSearchInTags:true,chkSearchExtendedFields:true,txtItemsPerPage:_11f,txtItemsPerPageWithPreview:_120};for(var n in opts){if(config.options[n]==undefined){config.options[n]=opts[n];}}
config.shadowTiddlers.AdvancedOptions+="\n<<option chkUseYourSearch>> Use 'Your Search' //([[more options|YourSearch Options]]) ([[help|YourSearch Help]])// ";config.shadowTiddlers["YourSearch Help"]="!Field Search\nWith the Field Search you can restrict your search to certain fields of a tiddler, e.g"+" only search the tags or only the titles. The general form is //fieldname//'':''//textToSearch// (e."+"g. {{{title:intro}}}). In addition one-character shortcuts are also supported for the standard field"+"s {{{title}}}, {{{text}}} and {{{tags}}}:\n|!What you want|!What you type|!Example|\n|Search ''titles "+"only''|start word with ''!''|{{{!jonny}}} (shortcut for {{{title:jonny}}})|\n|Search ''contents/text "+"only''|start word with ''%''|{{{%football}}} (shortcut for {{{text:football}}})|\n|Search ''tags only"+"''|start word with ''#''|{{{#Plugin}}} (shortcut for {{{tags:Plugin}}})|\n\nUsing this feature you may"+" also search the extended fields (\"Metadata\") introduced with TiddlyWiki 2.1, e.g. use {{{priority:1"+"}}} to find all tiddlers with the priority field set to \"1\".\n\nYou may search a word in more than one"+" field. E.g. {{{!#Plugin}}} (or {{{title:tags:Plugin}}} in the \"long form\") finds tiddlers containin"+"g \"Plugin\" either in the title or in the tags (but does not look for \"Plugin\" in the text). \n\n!Boole"+"an Search\nThe Boolean Search is useful when searching for multiple words.\n|!What you want|!What you "+"type|!Example|\n|''All words'' must exist|List of words|{{{jonny jeremy}}} (or {{{jonny and jeremy}}}"+")|\n|''At least one word'' must exist|Separate words by ''or''|{{{jonny or jeremy}}}|\n|A word ''must "+"not exist''|Start word with ''-''|{{{-jonny}}} (or {{{not jonny}}})|\n\n''Note:'' When you specify two"+" words, separated with a space, YourSearch finds all tiddlers that contain both words, but not neces"+"sarily next to each other. If you want to find a sequence of word, e.g. '{{{John Brown}}}', you need"+" to put the words into quotes. I.e. you type: {{{\"john brown\"}}}.\n\nUsing parenthesis you may change "+"the default \"left to right\" evaluation of the boolean search. E.g. {{{not (jonny or jeremy)}}} finds"+" all tiddlers that contain neither \"jonny\" nor \"jeremy. In contrast to this {{{not jonny or jeremy}}"+"} (i.e. without parenthesis) finds all tiddlers that either don't contain \"jonny\" or that contain \"j"+"eremy\".\n\n!'Exact Word' Search\nBy default a search result all matches that 'contain' the searched tex"+"t. E.g. if you search for {{{Task}}} you will get all tiddlers containing 'Task', but also '~Complet"+"edTask', '~TaskForce' etc.\n\nIf you only want to get the tiddlers that contain 'exactly the word' you"+" need to prefix it with a '='. E.g. typing '=Task' will find the tiddlers that contain the word 'Tas"+"k', ignoring words that just contain 'Task' as a substring.\n\n!~CaseSensitiveSearch and ~RegExpSearch"+"\nThe standard search options ~CaseSensitiveSearch and ~RegExpSearch are fully supported by YourSearc"+"h. However when ''~RegExpSearch'' is on Filtered and Boolean Search are disabled.\n\nIn addition you m"+"ay do a \"regular expression\" search even with the ''~RegExpSearch'' set to false by directly enterin"+"g the regular expression into the search field, framed with {{{/.../}}}. \n\nExample: {{{/m[ae][iy]er/"+"}}} will find all tiddlers that contain either \"maier\", \"mayer\", \"meier\" or \"meyer\".\n\n!~JavaScript E"+"xpression Filtering\nIf you are familiar with JavaScript programming and know some TiddlyWiki interna"+"ls you may also use JavaScript expression for the search. Just enter a JavaScript boolean expression"+" into the search field, framed with {{{ { ... } }}}. In the code refer to the variable tiddler and e"+"valuate to {{{true}}} when the given tiddler should be included in the result. \n\nExample: {{{ { tidd"+"ler.modified > new Date(\"Jul 4, 2005\")} }}} returns all tiddler modified after July 4th, 2005.\n\n!Com"+"bined Search\nYou are free to combine the various search options. \n\n''Examples''\n|!What you type|!Res"+"ult|\n|{{{!jonny !jeremy -%football}}}|all tiddlers with both {{{jonny}}} and {{{jeremy}}} in its tit"+"les, but no {{{football}}} in content.|\n|{{{#=Task}}}|All tiddlers tagged with 'Task' (the exact wor"+"d). Tags named '~CompletedTask', '~TaskForce' etc. are not considered.|\n\n!Access Keys\nYou are encour"+"aged to use the access keys (also called \"shortcut\" keys) for the most frequently used operations. F"+"or quick reference these shortcuts are also mentioned in the tooltip for the various buttons etc.\n\n|"+"!Key|!Operation|\n|{{{Alt-F}}}|''The most important keystroke'': It moves the cursor to the search in"+"put field so you can directly start typing your query. Pressing {{{Alt-F}}} will also display the pr"+"evious search result. This way you can quickly display multiple tiddlers using \"Press {{{Alt-F}}}. S"+"elect tiddler.\" sequences.|\n|{{{ESC}}}|Closes the [[YourSearch Result]]. When the [[YourSearch Resul"+"t]] is already closed and the cursor is in the search input field the field's content is cleared so "+"you start a new query.|\n|{{{Alt-1}}}, {{{Alt-2}}},... |Pressing these keys opens the first, second e"+"tc. tiddler from the result list.|\n|{{{Alt-O}}}|Opens all found tiddlers.|\n|{{{Alt-P}}}|Toggles the "+"'Preview Text' mode.|\n|{{{Alt-'<'}}}, {{{Alt-'>'}}}|Displays the previous or next page in the [[Your"+"Search Result]].|\n|{{{Return}}}|When you have turned off the 'as you type' search mode pressing the "+"{{{Return}}} key actually starts the search (as does pressing the 'search' button).|\n\n//If some of t"+"hese shortcuts don't work for you check your browser if you have other extensions installed that alr"+"eady \"use\" these shortcuts.//";config.shadowTiddlers["YourSearch Options"]="|>|!YourSearch Options|\n|>|<<option chkUseYourSearch>> Use 'Your Search'|\n|!|<<option chkPreviewText"+">> Show Text Preview|\n|!|<<option chkSearchAsYouType>> 'Search As You Type' Mode (No RETURN required"+" to start search)|\n|!|Default Search Filter:<<option chkSearchInTitle>>Title ('!') <<option chk"+"SearchInText>>Text ('%') <<option chkSearchInTags>>Tags ('#') <<option chkSearchExtendedFiel"+"ds>>Extended Fields<html><br><font size=\"-2\">The fields of a tiddlers that are searched when you don"+"'t explicitly specify a filter in the search text <br>(Explictly specify fields using one or more '!"+"', '%', '#' or 'fieldname:' prefix before the word/text to find).</font></html>|\n|!|Number of items "+"on search result page: <<option txtItemsPerPage>>|\n|!|Number of items on search result page with pre"+"view text: <<option txtItemsPerPageWithPreview>>|\n";config.shadowTiddlers["YourSearchStyleSheet"]="/***\n!~YourSearchResult Stylesheet\n***/\n/*{{{*/\n.yourSearchResult {\n\tposition: absolute;\n\twidth: 800"+"px;\n\n\tpadding: 0.2em;\n\tlist-style: none;\n\tmargin: 0;\n\n\tbackground: #ffd;\n\tborder: 1px solid DarkGra"+"y;\n}\n\n/*}}}*/\n/***\n!!Summary Section\n***/\n/*{{{*/\n.yourSearchResult .summary {\n\tborder-bottom-width:"+" thin;\n\tborder-bottom-style: solid;\n\tborder-bottom-color: #999999;\n\tpadding-bottom: 4px;\n}\n\n.yourSea"+"rchRange, .yourSearchCount, .yourSearchQuery {\n\tfont-weight: bold;\n}\n\n.yourSearchResult .summary ."+"button {\n\tfont-size: 10px;\n\n\tpadding-left: 0.3em;\n\tpadding-right: 0.3em;\n}\n\n.yourSearchResult .summa"+"ry .chkBoxLabel {\n\tfont-size: 10px;\n\n\tpadding-right: 0.3em;\n}\n\n/*}}}*/\n/***\n!!Items Area\n***/\n/*{{{*"+"/\n.yourSearchResult .marked {\n\tbackground: none;\n\tfont-weight: bold;\n}\n\n.yourSearchItem {\n\tmargin-to"+"p: 2px;\n}\n\n.yourSearchNumber {\n\tcolor: #808080;\n}\n\n\n.yourSearchTags {\n\tcolor: #008000;\n}\n\n.yourSearc"+"hText {\n\tcolor: #808080;\n\tmargin-bottom: 6px;\n}\n\n/*}}}*/\n/***\n!!Footer\n***/\n/*{{{*/\n.yourSearchFoote"+"r {\n\tmargin-top: 8px;\n\tborder-top-width: thin;\n\tborder-top-style: solid;\n\tborder-top-color: #999999;"+"\n}\n\n.yourSearchFooter a:hover{\n\tbackground: none;\n\tcolor: none;\n}\n/*}}}*/\n/***\n!!Navigation Bar\n***/"+"\n/*{{{*/\n.yourSearchNaviBar a {\n\tfont-size: 16px;\n\tmargin-left: 4px;\n\tmargin-right: 4px;\n\tcolor: bla"+"ck;\n\ttext-decoration: underline;\n}\n\n.yourSearchNaviBar a:hover {\n\tbackground-color: none;\n}\n\n.yourSe"+"archNaviBar .prev {\n\tfont-weight: bold;\n\tcolor: blue;\n}\n\n.yourSearchNaviBar .currentPage {\n\tcolor: #"+"FF0000;\n\tfont-weight: bold;\n\ttext-decoration: none;\n}\n\n.yourSearchNaviBar .next {\n\tfont-weight: bold"+";\n\tcolor: blue;\n}\n/*}}}*/\n";config.shadowTiddlers["YourSearchResultTemplate"]="<!--\n{{{\n-->\n<span macro=\"yourSearch if found\">\n<!-- The Summary Header ============================"+"================ -->\n<table class=\"summary\" border=\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"0\">"+"<tbody>\n <tr>\n\t<td align=\"left\">\n\t\tYourSearch Result <span class=\"yourSearchRange\" macro=\"yourSearc"+"h itemRange\"></span>\n\t\t of <span class=\"yourSearchCount\" macro=\"yourSearch count\"></span>\n"+"\t\tfor <span class=\"yourSearchQuery\" macro=\"yourSearch query\"></span>\n\t</td>\n\t<td class=\"yourSea"+"rchButtons\" align=\"right\">\n\t\t<span macro=\"yourSearch chkPreviewText\"></span><span class=\"chkBoxLabel"+"\">preview text</span>\n\t\t<span macro=\"yourSearch newTiddlerButton\"></span>\n\t\t<span macro=\"yourSearch openAllButton\"></span>\n\t\t<span macro=\"yourSearch lin"+"kButton 'YourSearch Options' options 'Configure YourSearch'\"></span>\n\t\t<span macro=\"yourSearch linkB"+"utton 'YourSearch Help' help 'Get help how to use YourSearch'\"></span>\n\t\t<span macro=\"yourSearch clo"+"seButton\"></span>\n\t</td>\n </tr>\n</tbody></table>\n\n<!-- The List of Found Tiddlers ================="+"=========================== -->\n<div id=\"yourSearchResultItems\" itemsPerPage=\"25\" itemsPerPageWithPr"+"eview=\"10\"></div>\n\n<!-- The Footer (with the Navigation) ==========================================="+"= -->\n<table class=\"yourSearchFooter\" border=\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"0\"><tbody"+">\n <tr>\n\t<td align=\"left\">\n\t\tResult page: <span class=\"yourSearchNaviBar\" macro=\"yourSearch naviBar"+"\"></span>\n\t</td>\n\t<td align=\"right\"><span macro=\"yourSearch version\"></span>, <span macro=\"yourSearc"+"h copyright\"></span>\n\t</td>\n </tr>\n</tbody></table>\n<!-- end of the 'tiddlers found' case ========="+"================================== -->\n</span>\n\n\n<!-- The \"No tiddlers found\" case ================="+"========================== -->\n<span macro=\"yourSearch if not found\">\n<table class=\"summary\" border="+"\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"0\"><tbody>\n <tr>\n\t<td align=\"left\">\n\t\tYourSearch Resu"+"lt: No tiddlers found for <span class=\"yourSearchQuery\" macro=\"yourSearch query\"></span>.\n\t</td>\n\t<t"+"d class=\"yourSearchButtons\" align=\"right\">\n\t\t<span macro=\"yourSearch newTiddlerButton\"></span>\n\t\t<span macro=\"yourSearch linkButton 'YourSearch Options'"+" options 'Configure YourSearch'\"></span>\n\t\t<span macro=\"yourSearch linkButton 'YourSearch Help' help"+" 'Get help how to use YourSearch'\"></span>\n\t\t<span macro=\"yourSearch closeButton\"></span>\n\t</td>\n <"+"/tr>\n</tbody></table>\n</span>\n\n\n<!--\n}}}\n-->\n";config.shadowTiddlers["YourSearchItemTemplate"]="<!--\n{{{\n-->\n<span class='yourSearchNumber' macro='foundTiddler number'></span>\n<span class='yourSea"+"rchTitle' macro='foundTiddler title'/></span> - \n<span class='yourSearchTags' macro='found"+"Tiddler field tags 50'/></span>\n<span macro=\"yourSearch if previewText\"><div class='yourSearchText' macro='fo"+"undTiddler field text 250'/></div></span>\n<!--\n}}}\n-->";config.shadowTiddlers["YourSearch"]="<<tiddler [[YourSearch Help]]>>";config.shadowTiddlers["YourSearch Result"]="The popup-like window displaying the result of a YourSearch query.";config.macros.search.handler=_157;var _20a=function(){if(config.macros.search.handler!=_157){alert("Message from YourSearchPlugin:\n\n\nAnother plugin has disabled the 'Your Search' features.\n\n\nYou may "+"disable the other plugin or change the load order of \nthe plugins (by changing the names of the tidd"+"lers)\nto enable the 'Your Search' features.");}};setTimeout(_20a,5000);abego.YourSearch.getStandardRankFunction=function(){return _ff;};abego.YourSearch.getRankFunction=function(){return abego.YourSearch.getStandardRankFunction();};abego.YourSearch.getCurrentTiddler=function(){return _13c;};abego.YourSearch.closeResult=function(){_12a();};abego.YourSearch.getFoundTiddlers=function(){return _f2;};abego.YourSearch.getQuery=function(){return _f3;};abego.YourSearch.onShowResult=function(_20b){highlightHack=_f3?_f3.getMarkRegExp():null;if(!_20b){_13d.setItems(_f6());}
if(!_124){_124=createTiddlyElement(document.body,"div",_121,"yourSearchResult");}else{if(_124.parentNode!=document.body){document.body.appendChild(_124);}}
_146();highlightHack=null;};})();}
//%/
20130612 - Spoke to Rekha regarding the need for this activity to happen. Later, briefed, to the best of my ability, Amit on the approach and what needed to happen.
20130612 - Chintan confirmed that records added to INVOIC02. I sent email to Ahmed explaining the situation.
//{{{
//requires DatePicker: http://svn.tiddlywiki.org/Trunk/contributors/SaqImtiaz/libraries/DatePicker.js
if (DatePicker) {
merge(config.macros, {
calendarPopup: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var dateBox = createTiddlyButton(place,params[0],params[1]);
dateBox.style.cursor='pointer';
DatePicker.create(dateBox,(new Date()),function(el,objDate) {
// mostly copy/pasted from NewSavedTiddler. refactor please
var title = prompt("Enter name for new Tickler","");
if (title) {
if (typeof config.macros.newTiddler.getName == "function") {
title = config.macros.newTiddler.getName(title); // from NewMeansNewPlugin
}
store.saveTiddler(title,title,"",config.options.txtUserName,new Date(),"Tickler Once "+config.macros.mgtdList.getRealm(),{'mgtd_date':objDate.convertToYYYYMMDDHHMM()});
story.displayTiddler(this,title);
}
});
}
},
dateChooser: {
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var useTiddler = tiddler;
if (params[0])
useTiddler = store.fetchTiddler(params[0]);
var curVal = useTiddler.fields['mgtd_date'] || undefined;
var startDate = curVal ? Date.convertFromYYYYMMDDHHMM(curVal) : null;
var dateBox = createTiddlyElement(place,'input',null,'dateBox');
var dateFormat = config.mGTD.getOptTxt('ticklerdateformat');
var defaultDateFormat = 'ddd, DD-mmm-YY';
if (!dateFormat) {
// makes it nicer for upgraders who don't have a format set
dateFormat = defaultDateFormat;
config.mGTD.setOptTxt('ticklerdateformat', defaultDateFormat);
}
dateBox.value = startDate ? startDate.formatString(dateFormat) : '(set date)';
var callback = function(el,objDate){
el.value = objDate.formatString(dateFormat);
store.setValue(useTiddler, 'mgtd_date',objDate.convertToYYYYMMDDHHMM());
}
DatePicker.create(dateBox,startDate,callback);
}
},
addDay: {
label: {addDay:"+d", addWeek:"+w", addFortnight:"+f", addMonth:"+m", addYear:"+y" },
tooltip: {addDay:"day", addWeek:"week", addFortnight:"fortnight", addMonth:"month", addYear:"year" },
handler: function(place,macroName,params,wikifier,paramString,tiddler) {
var useTiddler = tiddler;
if (params[0]) useTiddler = store.fetchTiddler(params[0]);
var curVal = useTiddler.fields['mgtd_date'] || undefined;
var curDate = curVal ? Date.convertFromYYYYMMDDHHMM(curVal) : new Date();
// ensure ticklers don't have minutes/hours since new Date() has minutes/hours
curDate.setHours(0);
curDate.setMinutes(0);
curDate.setSeconds(0);
// call the applicable date method. happens to match the macroname. see MgtdDateUtils. sorry for confusing code.
curDate[macroName](1);
createTiddlyButton(place,config.macros.addDay.label[macroName],"add a "+config.macros.addDay.tooltip[macroName],function() {
store.setValue(useTiddler, 'mgtd_date',curDate.convertToYYYYMMDDHHMM());
return false;
});
}
}
});
config.macros.addWeek = config.macros.addDay;
config.macros.addFortnight = config.macros.addDay;
config.macros.addMonth = config.macros.addDay;
config.macros.addYear = config.macros.addDay;
} // if (DatePicker)
//}}}