I’ve recently learned that it’s possible and even fairly easy to create a state machine workflow using SharePoint Designer. Necessity is the mother of invention and all that good stuff and I had a need this week that looked for an invention. Coincidentally, ನಾನು ಅಡ್ಡಲಾಗಿ ಬಂದ ಈ MSDN ವೇದಿಕೆ ಪೋಸ್ಟ್ as well. My personal experience this week and that "independent confirmation" lends strength to my conviction. I plan to write about this at greater length with a full blown example, ಆದರೆ ಇಲ್ಲಿ ಅದರ ಸಾರಾಂಶ ಇಲ್ಲಿದೆ:
- ವಿಧಾನ ಒಂದು ಕೆಲಸದೊತ್ತಡದ ಪಟ್ಟಿಯನ್ನು ಐಟಂ ಬದಲಾಯಿಸಬಹುದು ಎಂದು ವಾಸ್ತವವಾಗಿ leverages, thereby triggering a new workflow. I’ve normally considered this to be a nuisance and even semaphores ಬಳಸಿಕೊಂಡು ಬಗ್ಗೆ ಬ್ಲಾಗಿನಲ್ಲಿ ಬರೆದಿದ್ದರು ಇದು ನಿರ್ವಹಿಸಲು.
- ಶೇರ್ಪಾಯಿಂಟ್ ಅನೇಕ ಸ್ವತಂತ್ರ ಕಾರ್ಯಗಳಲ್ಲಿ ಒಂದು ನಿರ್ದಿಷ್ಟ ಪಟ್ಟಿ ಐಟಂ ವಿರುದ್ಧ ಸಕ್ರಿಯ ಅನುಮತಿಸುತ್ತದೆ.
ಇದು ಸಂರಚಿಸಲು:
- ನಿಮ್ಮ ರಾಜ್ಯದ ಯಂತ್ರ ವಿನ್ಯಾಸ (ಅಂದರೆ, ರಾಜ್ಯಗಳು ಮತ್ತು ಒಂದು ಮತ್ತೊಂದಕ್ಕೆ ಹೇಗೆ ರಾಜ್ಯಗಳ ಪರಿವರ್ತನೆ).
- ಪ್ರತ್ಯೇಕ ಕೆಲಸದೊತ್ತಡದ ಮಾಹಿತಿ ಪ್ರತಿ ರಾಜ್ಯದ ಅಳವಡಿಸಿ.
- ಪಟ್ಟಿ ಅಂಶದಲ್ಲಿ ಯಾವುದೇ ಬದಲಾವಣೆಗೆ ಪ್ರತಿಕ್ರಿಯೆಯಾಗಿ ಕಾರ್ಯಗತಗೊಳಿಸಲು ಈ ರಾಜ್ಯದ ಕಾರ್ಯಗಳಲ್ಲಿ ಪ್ರತಿಯೊಂದು ಸಂರಚಿಸಿ.
ಪ್ರತಿ ರಾಜ್ಯದ ಕೆಲಸದೊತ್ತಡದ ಈ ಒರಟಾದ ಮಾದರಿಯನ್ನು ಅನುಸರಿಸುತ್ತದೆ:
- ಆರಂಭಕ್ಕೆ ನಂತರ, determine whether it should really run by inspecting state information in the "current item". Abort if not.
- ಕೆಲಸ.
- Update the "current item" with new state information. This triggers an update to the current item and fires off all the state workflows.
ಪಕ್ಕಕ್ಕೆ ಒಂದು ದೃಢಪಡಿಸುವ ರಾಜ್ಯದ ಯಂತ್ರ ಕೆಲಸದೊತ್ತಡದ ರಚಿಸಬಹುದು ಎಂದು ಸ್ಪಷ್ಟ ಪ್ರಯೋಜನವನ್ನು ನಿಂದ, ಎಲ್ಲ ರಾಜ್ಯದ ಮಾಹಿತಿ ಕಟ್ಟಡ KPIs ಮತ್ತು ಆಸಕ್ತಿದಾಯಕ ಅಭಿಪ್ರಾಯಗಳಿಗೆ ಸೊಗಸಾದ ಆಗಿದೆ.
ಇದು ಸಾಕಷ್ಟು ಗಣನೀಯ ನ್ಯೂನತೆಯೆಂದರೆ ಹೊಂದಿದೆ — standard workflow history tracking is even more useless than normal That’s easily remedied, ಹೇಗಾದರೂ. Store all of your audit type information in a custom list. That’s probably a good idea even for vanilla sequential workflow, but that’s for another blog post
I call this a "mea culpa" ನಾನು ಏಕೆಂದರೆ, ಶೋಚನೀಯವಾಗಿ, said more than once on forums and elsewhere that one must use visual studio to create a state machine workflow. That simply isn’t true.
</ಕೊನೆಯಲ್ಲಿ>