12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357 |
- MWF.xScript = MWF.xScript || {};
- MWF.xScript.Environment = function(ev){
- var _data = ev.data;
- var _form = ev.form;
- var _forms = ev.forms;
- this.appType = "process";
- this.library = COMMON;
- //this.library.version = "4.0";
- this.power = {
- "isManager": MWF.AC.isProcessManager() || _form.businessData.control.allowReroute,
- "isReseter": _form.businessData.control.allowReset,
- "isDelete": _form.businessData.control.allowDeleteWork,
- "isPront": true,
- "isPrint": true
- };
- //data
- var getJSONData = function(jData){
- return new MWF.xScript.JSONData(jData, function(data, key, _self){
- var p = {"getKey": function(){return key;}, "getParent": function(){return _self;}};
- while (p && !_forms[p.getKey()]) p = p.getParent();
- //if (p) if (p.getKey()) if (_forms[p.getKey()]) _forms[p.getKey()].resetData();
- var k = (p) ? p.getKey() : "";
- if (k) if(_forms[k]) if(_forms[k].resetData) _forms[k].resetData();
- //if(p) if(p.getKey()) if(_forms[p.getKey()]) if(_forms[p.getKey()].render) _forms[p.getKey()].render();
- }, "", null, _form);
- };
- this.setData = function(data){
- /**
- * data对象是流程平台中,流程实例的业务数据;以及内容管理平台中,文档实例的业务数据。<br/>
- * 这些数据一般情况下是通过您创建的表单收集而来的,也可以通过脚本进行创建和增删改查操作。<br/>
- * data对象基本上是一个Object对象,您可以用访问Object对象的方法访问data对象的所有数据,但增加和删除数据时略有不同。
- * @module data
- * @o2cn 业务数据
- * @o2category web
- * @o2ordernumber 10
- * @example
- * //您可以在表单或流程的各个嵌入脚本中,通过this来获取当前实例的业务数据,如下:
- * var data = this.data;
- */
- this.data = getJSONData(data);
- /**
- * 访问或修改data对象的数据。<br/><br/>
- * data数据用于存储表单获取的数据,所有属性都是动态的,其格式和访问方式都和JSON类似。<br/>
- * 在表单脚本中使用data对象,实现了data和表单可编辑元素的双向绑定。<br/>
- * 改变data对象,会自动更新表单元素,修改表单可编辑元素,也会自动修改data对象。<br/>
- * <b>数据赋值(this.data.subject = '')仅适用于表单上有该字段组件;建议使用this.data.add("subject","",true)方法,适用所有情况。</b>
- * @member {String|Number} [[property]]
- * @memberOf module:data
- * @instance
- * @example
- * var value = this.data.subject; //获取名为subject的数据值
- *
- * //将subject的值修改为'123'。
- * //需要注意的是,用这种方式创建新字段,必须要在当前表单上有一个名为‘subject’的字段组件。
- * //如果表单上没有该组件,可以使用this.data.add('subject','123',true)。给已有字段赋值则没有这个限制。
- * this.data.subject = '123';
- *
- * @example
- * <caption>
- * <b>获取流程文档中的数据网格的值</b>:<br/>
- * 如有以下数据网格:
- * <img src="img/module/data/datagrid.jpg">
- * 其数据网格设计如下(数据网格id为:datagrid):
- * <img src="img/module/data/datagridDesign.jpg">
- * </caption>
- * //获取流程文档中的数据网格的值
- * var data = this.data.datagrid;
- *
- * //获取到的data值格式如下:
- * {
- * "data": [
- * {
- * "amountCol": { "amount": "12000" },
- * "countCol": { "number": "10" },
- * "nameCol": { "name": "手机" },
- * "priceCol": { "price": "1200" }
- * },
- * {
- * "amountCol": { "amount": "15000" },
- * "countCol": { "number": "5" },
- * "nameCol": { "name": "电脑" },
- * "priceCol": { "price": "3000" }
- * }
- * ],
- * "total": {
- * "amountCol": "27000",
- * "countCol": "15"
- * }
- * }
- *
- *
- * //获取到数据网格中的其他数据:
- *
- * //获取数据网格中的第一条数据
- * var data = this.data.datagrid.data[0];
- *
- * //获取数据网格中的第一条数据的 nameCol 列的值
- * var data = this.data.datagrid.data[0].nameCol.name;
- *
- * //获取数据网格中的 amountCol 列的总计值
- * var data = this.data.datagrid.total.amountCol;
- *
- *@example
- * <caption>
- * <b>修改数据网格中的数据</b></br>
- * 经过本样例修改后,数据网格将变为:</br>
- * <img src="img/module/data/datagrid2.jpg">
- * </caption>
- * //修改数据网格中的第一条数据的 nameCol 列的值
- * this.data.datagrid.data[0].nameCol.name='平板电脑';
- */
- /**
- * 为data对象添加一个数据节点。
- * @instance
- * @method add
- * @memberOf module:data
- * @param {(String|Number)} key - 要添加的新的数据节点名称或数组索引号。
- * @param {(String|Number|Array|JsonObject)} value - 新的数据节点的值。
- * @param {Boolean} [overwrite] - 如果要添加的节点已经存在,是否覆盖。默认为 false。
- * @return {(String|Number|Array|JsonObject)} 新添加的数据节点或原有的同名节点。
- * @o2syntax
- * var newData = this.data.add(key, value, overwrite);
- * @example
- * //为data添加一个名为"remark"值为"I am remark"的数据
- * this.data.add("remark", "I am remark");
- * @example
- * //为data添加一个名为"person"的Object对象数据
- * var person = this.data.add("person", {});
- * person.add("name", "Tom");
- * person.add("age", 23);
- *
- * //或者可以这样
- * var person = this.data.add("person", {name: "Tom", "age": "23"});
- * @example
- * //为data添加一个名为"orders"的数组对象数据
- * var orders = this.data.add("orders", []);
- * orders.add({name: "phone", count: 5});
- * orders.add({name: "computer", count: 10});
- * orders[0].add("count", 10, true); //将第一条数据的count修改为10
- *
- * //或者可以这样
- * var orders = this.data.add("orders", [
- * {name: "phone", count: 5},
- * {name: "computer", count: 10}
- * ]);
- * //将第一条数据修改为name为mobile; count为10
- * orders.add(0, {name: "mobile", count: 10}, true);
- */
- /**保存data对象。不触发事件。
- * 不建议在queryLoad、beforeSave和afterSave中使用本方法。
- * @method save
- * @static
- * @memberOf module:data
- * @param {Function} [callback] - 保存成功后的回调函数。
- * @o2syntax
- * this.data.save(callback);
- * @example
- * this.data.save(function(json){
- * this.form.notice("save success!", "success")
- *});
- */
- this.data.save = function(callback){
- _form.saveFormData(callback)
- // var formData = {
- // "data": data,
- // "sectionList": _form.getSectionList()
- // };
- // _form.workAction.saveSectionData(function(){if (callback) callback();}.bind(this), null, (ev.work.id || ev.workCompleted.id), formData);
- }
- };
- this.setData(_data);
- //task
- //this.task = ev.task;
- //this.task.process = function(routeName, opinion, callback){
- // _form.submitWork(routeName, opinion, callback);
- //};
- //inquiredRouteList
- //this.inquiredRouteList = null;
- //workContext
- var _getWorkContextList = function(method, id, callback, error){
- var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- var list;
- var p = o2.Actions.get("x_processplatform_assemble_surface")[method](id, function(json){
- list = json.data;
- if (cb) cb(list);
- return list;
- }, ecb, !!callback);
- return (!!callback) ? p : list;
- };
- /**
- * 您可以通过workContext获取和流程相关的流程实例对象数据。
- * @module workContext
- * @o2cn 流程实例
- * @o2category web
- * @o2range {Process}
- * @o2ordernumber 20
- * @o2syntax
- * //您可以在表单或流程的各个嵌入脚本中,通过this来获取当前流程实例数据,如下:
- * var context = this.workContext;
- */
- this.workContext = {
- // * <div><br/>
- // * 下面的Work对象和WorkCompleted对象为后台返回的数据,在前端脚本中我们对这两个对象进行了修改和补充,如下:
- // * </div>
- // * <pre><code class='language-js'>{
- // * "creatorPersonDn": "张三@zhangsan@P", //创建人,可能为空,如果由系统创建.
- // * "creatorPerson": "张三", //创建人姓名
- // * "creatorIdentityDn": "张三@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //创建人Identity,可能为空,如果由系统创建.
- // * "creatorIdentity": "张三" //创建人姓名
- // * "creatorUnitDn": "开发部@c448d8bb-98b8-4305-9d3f-12537723cfcc@U", //创建人组织全称,如果由系统创建。
- // * "creatorUnit": "开发部", //创建人组织名称
- // * "creatorDepartment": "开发部", //创建人组织名称,同creatorUnit
- // * "creatorCompany": "xx公司" //创建人顶层组织名称,creatorUnitLevelName的第一段
- // * }</code></pre>
- /**
- * 获取当前流程实例对象:work对象或workCompleted对象。
- * @method getWork
- * @static
- * @return {(Work|WorkCompleted)} 流程实例对象;如果流程已结束,返回已结束的流程实例对象。
- * @o2ActionOut x_processplatform_assemble_surface.WorkAction.manageGet|example=WorkParsed|extension=Work|ignoreNoDescr=true|ignoreProps=[properties,manualTaskIdentityMatrix]|Work对象:
- * @o2ActionOut x_processplatform_assemble_surface.WorkCompletedAction.get|example=WorkCompletedParsed|extension=Work|ignoreProps=[properties,data,taskCompletedList,readCompletedList,reviewList,recordList,workLogList,storeForm,mobileStoreForm]|WorkCompleted对象:
- * @o2syntax
- * var work = this.workContext.getWork();
- */
- "getWork": function(){return ev.work || ev.workCompleted;},
- /**
- * 获取当前流程实例所在的活动节点对象:activity对象。
- * @method getActivity
- * @static
- * @return {(Activity|Null)} 当前流程实例所在的活动节点对象,如果当前流程实例已流转完成,则返回null.
- * <pre><code class='language-js'>{
- * "id": "801087c5-a4e6-4b91-bf4d-a81cdaa04471", //节点ID
- * "name": "办理", //节点名称
- * "description": "", //节点描述
- * "alias": "", //节点别名
- * "resetRange": "department", //重置处理人范围
- * "resetCount": 0, //重置处理人数字
- * "allowReset": true, //是否允许重置
- * "manualMode": "single", //处理方式 单人single, 并行parallel, 串行queue, grab抢办
- * "customData": { //节点上的自定义属性,如果没有设置,不输出该值
- *
- * }
- * }</code></pre>
- * @o2syntax
- * var activity = this.workContext.getActivity();
- */
- "getActivity": function(){return ev.activity || null;},
- // * <div><br/>
- // * 下面的Task对象为后台返回的数据,脚本中我们对这它进行了修改和补充,如下:
- // * </div>
- // * <pre><code class='language-js'>{
- // * "personDn": "张三@zhangsan@P", //创建人,可能为空,如果由系统创建.
- // * "person": "张三", //创建人姓名
- // * "identityDn": "张三@481c9edc-5fb5-41f1-b5c2-6ea609082cdb@I", //创建人Identity,可能为空,如果由系统创建.
- // * "identity": "张三" //创建人姓名
- // * "unitDn": "开发部@c448d8bb-98b8-4305-9d3f-12537723cfcc@U", //创建人组织全称,如果由系统创建。
- // * "unit": "开发部", //创建人组织名称
- // * "department": "开发部", //创建人组织名称,unit
- // * "customData": {}, //流程活动上配置的自定义属性
- // * }</code></pre>
- /**
- * 当前流程实例正在流转中,并且当前用户有待办,则返回当前用户的待办对象,否则返回null。
- * @summary 获取当前流程与当前用户相关的待办对象:task对象。
- * @o2ActionOut x_processplatform_assemble_surface.TaskAction.get|example=TaskParsed|extension=Task|Task对象:
- * @method getTask
- * @static
- * @return {(Task|Null)} 当前用户的待办任务对象:task。当前用户没有对此流程实例的待办时,或流程实例已经流转结束,返回null。
- * @o2syntax
- * var task = this.workContext.getTask();
- */
- "getTask": function(){return ev.task || null;},
- /**
- * 获取当前流程实例的所有待办对象。如果流程实例已流转完成,则返回一个空数组。
- * @method getTaskList
- * @o2ActionOut x_processplatform_assemble_surface.TaskAction.listWithWork|example=Task
- * @static
- * @param {Function|Boolean} [callback] 正确获取待办数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取待办数组出错时的回调。
- * @return {(Task[]|Promise)} 待办任务列表,或resolve了待办对象列表的Promise对象.
- * @o2syntax
- * //本样例以同步执行
- * var taskList = this.workContext.getTaskList();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getTaskList( function(taskList){
- * //taskList 为待办数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getTaskList(true).then(function(taskList){
- * //taskList 为待办数组
- * });
- */
- "getTaskList": function(callback, error){
- if( ev.work.completedTime )return [];
- return _getWorkContextList("listTaskByWork", ev.work.id, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // var p = o2.Actions.get("x_processplatform_assemble_surface").listTaskByWork(ev.work.id, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // return list;
- // }, ecb, !!callback);
- // return (!!callback) ? p : list;
- },
- /**
- * 根据当前工作的job获取当前流程实例的所有待办对象。如果流程实例已流转完成,则返回一个空数组。
- * @method getTaskListByJob
- * @o2ActionOut x_processplatform_assemble_surface.TaskAction.listWithJob|example=Task
- * @static
- * @param {Function|Boolean} [callback] 正确获取待办数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取待办数组出错时的回调。
- * @return {(Task[]|Promise)} 待办任务列表,或resolve了待办对象列表的Promise对象.
- * @o2syntax
- * //本样例以同步执行
- * var taskList = this.workContext.getTaskListByJob();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getTaskListByJob( function(taskList){
- * //taskList 为待办数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getTaskListByJob(true).then(function(taskList){
- * //taskList 为待办数组
- * });
- */
- "getTaskListByJob": function(callback, error){
- return _getWorkContextList("listTaskByJob", ev.work.job, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // var p = o2.Actions.get("x_processplatform_assemble_surface").listTaskByJob(ev.work.job, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // return list;
- // }, ecb, !!callback);
- // return (!!callback) ? p : list;
- },
- /**
- * 获取当前流程实例的所有已办对象。如果流程实例没有任何人处理过,则返回一个空数组。
- * @method getTaskCompletedList
- * @static
- * @param {Function|Boolean} [callback] 正确获取已办数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取已办数组出错时的回调。
- * @return {(TaskCompleted[]|Promise)} 已办任务列表,或resolve了已办对象列表的Promise对象.
- * @o2ActionOut x_processplatform_assemble_surface.TaskCompletedAction.listWithWork|example=Task
- * @o2syntax
- * //本样例以同步执行
- * var taskCompletedList = this.workContext.getTaskCompletedList();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getTaskCompletedList(function(taskCompletedList){
- * //taskCompletedList 为已办数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getTaskCompletedList(true).then(function(taskCompletedList){
- * //taskCompletedList 为已办数组
- * });
- */
- "getTaskCompletedList": function(callback, error){
- return _getWorkContextList("listTaskCompletedByWorkOrWorkCompleted", ev.work.id, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // var p = o2.Actions.get("x_processplatform_assemble_surface").listTaskCompletedByWork(ev.work.id, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // }, ecb, !!callback);
- // return (!!callback) ? p : list;
- },
- /**
- * 根据当前工作的job获取当前流程实例的所有已办对象。如果流程实例没有任何人处理过,则返回一个空数组。
- * @method getTaskCompletedListByJob
- * @static
- * @param {Function|Boolean} [callback] 正确获取已办数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取已办数组出错时的回调。
- * @return {(TaskCompleted[]|Promise)} 已办任务列表,或resolve了已办对象列表的Promise对象.
- * @o2ActionOut x_processplatform_assemble_surface.TaskCompletedAction.listWithJob|example=Task
- * @o2syntax
- * //本样例以同步执行
- * var taskCompletedList = this.workContext.getTaskCompletedListByJob();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getTaskCompletedListByJob( function(taskCompletedList){
- * //taskCompletedList 为已办数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getTaskCompletedListByJob(true).then(function(taskCompletedList){
- * //taskCompletedList 为已办数组
- * });
- */
- "getTaskCompletedListByJob": function(callback, error){
- return _getWorkContextList("listTaskCompletedByJob", ev.work.job, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // var p = o2.Actions.get("x_processplatform_assemble_surface").listTaskCompletedByJob(ev.work.job, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // }, ecb, !!callback);
- // return (!!callback) ? p : list;
- },
- /**
- * @summary 获取当前流程实例的所有待阅对象数组。如果流程实例无待阅,则返回一个空数组。
- * @method getReadList
- * @static
- * @param {Function|Boolean} [callback] 正确获取待阅数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取待阅数组出错时的回调。
- * @return {(Read[]|Promise)} 当前流程实例的所有待阅对象数组, 或resolve了待阅对象列表的Promise对象.
- * @o2ActionOut x_processplatform_assemble_surface.ReadAction.get|example=Read
- * @o2syntax
- * //本样例以同步执行
- * var readList = this.workContext.getReadList();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getReadList( function(readList){
- * //readList 为待阅数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getReadList(true).then(function(readList){
- * //readList 为待阅数组
- * });
- */
- "getReadList": function(callback, error){
- return _getWorkContextList("listReadByWorkOrWorkCompleted", ev.work.id, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // o2.Actions.get("x_processplatform_assemble_surface").listReadByWork(ev.work.id, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // }, ecb, !!cb);
- // return list;
- },
- /**
- * @summary 根据当前工作的job获取当前流程实例的所有待阅对象。如果流程实例无待阅,则返回一个空数组。
- * @method getReadListByJob
- * @static
- * @param {Function|Boolean} [callback] 正确获取待阅数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取待阅数组出错时的回调。
- * @return {(Read[]|Promise)} 当前流程实例的所有待阅对象数组, 或resolve了待阅对象列表的Promise对象.
- * @o2ActionOut x_processplatform_assemble_surface.ReadAction.listWithJob|example=Read
- * @o2syntax
- * //本样例以同步执行
- * var readList = this.workContext.getReadListByJob();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getReadListByJob( function(readList){
- * //readList 为待阅数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getReadListByJob(true).then(function(readList){
- * //readList 为待阅数组
- * });
- */
- "getReadListByJob": function(callback, error){
- return _getWorkContextList("listReadByJob", ev.work.job, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // o2.Actions.get("x_processplatform_assemble_surface").listReadByJob(ev.work.job, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // }, ecb, !!cb);
- // return list;
- },
- /**
- * @summary 获取当前流程实例的所有已阅对象。如果流程实例没有已阅,则返回一个空数组。
- * @method getReadCompletedList
- * @static
- * @param {Function|Boolean} [callback] 正确获取已阅数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取已阅数组出错时的回调。
- * @return {(ReadCompleted[]|Promise)} 当前流程实例的所有已阅对象数组, 或resolve了已阅对象列表的Promise对象.
- * @o2ActionOut x_processplatform_assemble_surface.ReadCompletedAction.listWithWork|example=Read
- * @o2syntax
- * //本样例以同步执行
- * var readCompletedList = this.workContext.getReadCompletedList();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getReadCompletedList( function(readCompletedList){
- * //readCompletedList 为已阅数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getReadCompletedList(true).then(function(readCompletedList){
- * //readCompletedList 为已阅数组
- * });
- */
- "getReadCompletedList": function(callback, error){
- return _getWorkContextList("listReadCompletedByWorkOrWorkCompleted", ev.work.id, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // o2.Actions.get("x_processplatform_assemble_surface").listReadCompletedByWork(ev.work.id, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // }, ecb, !!cb);
- // return list;
- },
- /**
- * @summary 根据当前工作的job获取当前流程实例的所有已阅对象。如果流程实例没有已阅,则返回一个空数组。
- * @method getReadCompletedListByJob
- * @static
- * @param {Function|Boolean} [callback] 正确获取已阅数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取已阅数组出错时的回调。
- * @return {(ReadCompleted[]|Promise)} 当前流程实例的所有已阅对象数组, 或resolve了已阅对象列表的Promise对象.
- * @o2ActionOut x_processplatform_assemble_surface.ReadCompletedAction.listWithJob|example=Read
- * @o2syntax
- * //本样例以同步执行
- * var readCompletedList = this.workContext.getReadCompletedListByJob();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getReadCompletedListByJob( function(readCompletedList){
- * //readCompletedList 为已阅数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getReadCompletedListByJob(true).then(function(readCompletedList){
- * //readCompletedList 为已阅数组
- * });
- */
- "getReadCompletedListByJob": function(callback, error){
- return _getWorkContextList("listReadCompletedByJob", ev.work.job, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // o2.Actions.get("x_processplatform_assemble_surface").listReadCompletedByJob(ev.work.job, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // }, ecb, !!cb);
- // return list;
- },
- /**
- * @summary 根据当前工作的job获取当前流程实例的所有review对象。如果流程实例没有review,则返回一个空数组。
- * @method getReviewList
- * @static
- * @param {Function|Boolean} [callback] 正确获取review数组的回调,或者一个布尔值,如果此参数判断为true,则本方法以异步执行,并返回Promise,否则同步执行
- * @param {Function} [error] 获取已阅数组出错时的回调。
- * @return {(Review[]|Promise)} 当前流程实例的所有review对象数组, 或resolve了review对象列表的Promise对象.
- * @o2ActionOut x_processplatform_assemble_surface.ReviewAction.listWithJob|example=Review
- * @o2syntax
- * //本样例以同步执行
- * var reviewList = this.workContext.getReviewList();
- * @o2syntax
- * //本样例以异步执行
- * this.workContext.getReviewList( function(reviewList){
- * //reviewList 为review对象数组
- * });
- * @o2syntax
- * //本样例使用Promise
- * this.workContext.getReviewList(true).then(function(reviewList){
- * //reviewList 为review对象数组
- * });
- */
- "getReviewList": function(callback, error){
- return _getWorkContextList("listReviewByJob", ev.work.job, callback, error);
- // var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- // var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- // var list;
- // o2.Actions.get("x_processplatform_assemble_surface").listReadCompletedByJob(ev.work.job, function(json){
- // list = json.data;
- // if (cb) cb(list);
- // }, ecb, !!cb);
- // return list;
- },
- /**
- * @summary 与getReviewList方法相同。
- * @method getReviewListByJob
- * @static
- * @see module:workContext.getReviewList
- */
- "getReviewListByJob": this.getReviewList,
- /**
- * @summary getTaskListByJob方法的别名。
- * @method getJobTaskList
- * @static
- * @see module:workContext.getTaskListByJob
- */
- "getJobTaskList": this.getTaskListByJob,
- /**
- * @summary getReadListByJob方法的别名。
- * @method getJobReadList
- * @static
- * @see module:workContext.getReadListByJob
- */
- "getJobReadList": this.getReadListByJob,
- /**
- * @summary getTaskCompletedListByJob方法的别名。
- * @method getJobTaskCompletedList
- * @static
- * @see module:workContext.getTaskCompletedListByJob
- */
- "getJobTaskCompletedList": this.getTaskCompletedListByJob,
- /**
- * @summary getReadCompletedListByJob方法的别名。
- * @method getJobReadCompletedList
- * @static
- * @see module:workContext.getReadCompletedListByJob
- */
- "getJobReadCompletedList": this.getReadCompletedListByJob,
- /**
- * @summary 与getReviewList方法相同。
- * @method getJobReviewList
- * @static
- * @see module:workContext.getReviewList
- */
- "getJobReviewList": this.getReviewList,
- /**
- * @summary 获取当前人对流程实例的权限。
- * @method getControl
- * @static
- * @return {WorkControl} 流程实例权限对象.
- * <pre><code class='language-js'>{
- * "allowVisit": true, //是否允许访问工作
- * "allowFlow": true, //是否允许继续流转(允许提交或重置处理人或加签)
- * "allowProcessing": true, //是否允许提交
- * "allowReadProcessing": false, //是否有待阅
- * "allowSave": true, //是否允许保存业务数据
- * "allowReset": false, //是否允许重置处理人
- * "allowReroute": false, //是否允许调度
- * "allowDelete": true, //是否允许删除流程实例
- * "allowAddSplit": false, //是否允许添加拆分分支
- * "allowRetract": false, //是否允许撤回
- * "allowRollback": false, //是否允许回溯流程
- * "allowPress": false, //是否允许发送办理提醒
- * "allowGoBack": false, //是否允许回退
- * "allowAddTask": false, //是否允许加签
- * "allowPause": false, //是否允许待办挂起
- * "allowResume": false, //是否允许待办从挂起状态恢复
- * }</code></pre>
- * @o2syntax
- * var control = this.workContext.getControl();
- */
- "getControl": function(){return ev.control;},
- /**
- * @summary 获取当前流程实例的所有流程记录(WorkLog)。
- * @method getWorkLogList
- * @static
- * @return {WorkLog[]} 流程记录对象.
- * @o2ActionOut x_processplatform_assemble_surface.WorkLogAction.listWithJob|example=WorkLog|ignoreProps=[properties,goBackFromActivityType]
- * @o2syntax
- * var workLogList = this.workContext.getWorkLogList();
- */
- "getWorkLogList": function(){return ev.workLogList;},
- /**
- * @summary 获取当前流程实例的所有流程记录(Record)。
- * @method getRecordList
- * @o2ActionOut x_processplatform_assemble_surface.RecordAction.listWithJob|example=Record
- * @static
- * @return {Record[]} 流程记录(Record)对象.
- * @o2syntax
- * var recordList = this.workContext.getRecordList();
- */
- "getRecordList": function(){return ev.recordList;},
- /**
- * @summary 获取当前流程实例的附件对象列表。
- * @method getAttachmentList
- * @static
- * @param {Function|boolean} [callback] 如果传入Funcation, 则作为正确获取附件对象数组的异步调用的回调;
- * 如果传入true,则发起异步请求获取附件列表,返回Promise对象;如果传入false, 则发起同步请求获取附件列表;
- * 如果不传入参数,则直接返回本地缓存中的attachmentList对象。
- * @param {Function} [error] 获取附件对象数组出错时的回调。
- * @return {WorkAttachmentData[]} 附件数据.
- * @o2ActionOut x_processplatform_assemble_surface.AttachmentAction.getWithWorkOrWorkCompleted|example=Attachment|ignoreProps=[properties]
- * @o2syntax
- * //从本地缓存获取附件列表
- * var attachmentList = this.workContext.getAttachmentList();
- *
- * //同步请求获取附件列表
- * var attachmentList = this.workContext.getAttachmentList(false);
- *
- * //异步请求获取附件列表
- * var promise = this.workContext.getAttachmentList(true);
- * promise.then(function(attachmentList){
- * //attachmentList 附件对象数组
- * })
- *
- * //异步请求获取附件列表
- * this.workContext.getAttachmentList( function(attachmentList){
- * //attachmentList 附件对象数组
- * });
- */
- "getAttachmentList": function(callback, error){
- if (!callback && callback !== false) {
- return ev.attachmentList;
- }
- var cb = (callback && o2.typeOf(callback)==="function") ? callback : null;
- var ecb = (error && o2.typeOf(error)==="function") ? error : null;
- var list;
- var p = o2.Actions.load("x_processplatform_assemble_surface").AttachmentAction.listWithJob(ev.work.job, function(json){
- list = json.data;
- if (cb) cb(list);
- return list;
- }, ecb, !!callback);
- return (callback) ? p : list;
- },
- /**
- * @summary 获取当前待办的可选路由。与task对象中的routeNameList取值相同。
- * @method getRouteList
- * @static
- * @return {String[]} 路由字符串数组.
- * @o2syntax
- * var routeList = this.workContext.getRouteList();
- */
- "getRouteList": function(){return (ev.task) ? ev.task.routeNameList: null;},
- "getInquiredRouteList": function(){return null;}
- // /**
- // * @summary 重新设置流程实例标题。。
- // * @method setTitle
- // * @static
- // * @param {String} title - 标题字符串.
- // * @o2syntax
- // * this.workContext.setTitle(title);
- // * @example
- // * this.workContext.setTitle("标题");
- // */
- // "setTitle": function(title){
- // if (!this.workAction){
- // MWF.require("MWF.xScript.Actions.WorkActions", null, false);
- // this.workAction = new MWF.xScript.Actions.WorkActions();
- // }
- // this.workAction.setTitle(ev.work.id, {"title": title});
- // }
- };
- this.workContent = this.workContext;
- var _redefineWorkProperties = function(work){
- if (work){
- work.creatorPersonDn = work.creatorPerson ||"";
- work.creatorUnitDn = work.creatorUnit ||"";
- work.creatorUnitDnList = work.creatorUnitList ||"";
- work.creatorIdentityDn = work.creatorIdentity ||"";
- var o = {
- "creatorPerson": {"get": function(){return this.creatorPersonDn.substring(0, this.creatorPersonDn.indexOf("@"));}},
- "creatorUnit": {"get": function(){return this.creatorUnitDn.substring(0, this.creatorUnitDn.indexOf("@"));}},
- "creatorDepartment": {"get": function(){return this.creatorUnitDn.substring(0, this.creatorUnitDn.indexOf("@"));}},
- "creatorIdentity": {"get": function(){return this.creatorIdentityDn.substring(0, this.creatorIdentityDn.indexOf("@"));}},
- // "creatorUnitList": {
- // "get": function(){
- // var v = [];
- // this.creatorUnitDnList.each(function(dn){
- // v.push(dn.substring(0, dn.indexOf("@")))
- // });
- // return v;
- // }
- // },
- "creatorCompany": {"get": function(){
- if (this.creatorUnitLevel || this.creatorUnitLevelName){
- var level = (this.creatorUnitLevel || this.creatorUnitLevelName).split("/");
- return level[0];
- }else{
- return this.creatorUnitDn.substring(0, this.creatorUnitDn.indexOf("@"));
- }
- }}
- };
- MWF.defineProperties(work, o);
- }
- return work;
- };
- var _redefineTaskProperties = function(task){
- if (task){
- task.personDn = task.person || "";
- task.unitDn = task.unit || "";
- task.unitDnList = task.unitList || "";
- task.identityDn = task.identity || "";
- var o = {
- "person": {"get": function(){return this.personDn.substring(0, this.personDn.indexOf("@"));}},
- "unit": {"get": function(){return this.unitDn.substring(0, this.unitDn.indexOf("@"));}},
- "department": {"get": function(){return this.unitDn.substring(0, this.unitDn.indexOf("@"));}},
- "identity": {"get": function(){return this.identityDn.substring(0, this.identityDn.indexOf("@"));}},
- // "unitList": {
- // "get": function(){
- // var v = [];
- // this.unitDnList.each(function(dn){
- // v.push(dn.substring(0, dn.indexOf("@")))
- // });
- // return v;
- // }
- // },
- "company": {"get": function(){return this.unitList[0];}}
- };
- MWF.defineProperties(task, o);
- }
- return task;
- };
- _redefineWorkProperties(this.workContext.getWork());
- _redefineTaskProperties(_redefineWorkProperties(this.workContext.getTask()));
- //dict
- this.Dict = MWF.xScript.createDict((_form.businessData.work || _form.businessData.workCompleted).application, "process");
- //unit
- var orgActions = null;
- var getOrgActions = function(){
- // if (!orgActions){
- // MWF.xDesktop.requireApp("Org", "Actions.RestActions", null, false);
- // orgActions = new MWF.xApplication.Org.Actions.RestActions ();
- // }
- if (!orgActions){
- MWF.require("MWF.xScript.Actions.UnitActions", null, false);
- orgActions = new MWF.xScript.Actions.UnitActions();
- }
- };
- var getNameFlag = function(name){
- var t = typeOf(name);
- if (t==="array"){
- var v = [];
- name.each(function(id){
- v.push((typeOf(id)==="object") ? (id.distinguishedName || id.id || id.unique || id.name) : id);
- });
- return v;
- }else{
- return [(t==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name];
- }
- };
- this.org = {
- //群组***************
- //获取群组--返回群组的对象数组
- /**
- 根据群组标识获取对应的群组对象数组:group对象数组
- */
- getGroup: function(name, async){
- getOrgActions();
- var data = {"groupList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- v = (v && v.length===1) ? v[0] : v
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listGroup(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var v = null;
- // orgActions.listGroup(data, function(json){v = json.data;}, null, false);
- // return (v && v.length===1) ? v[0] : v;
- },
- //查询下级群组--返回群组的对象数组
- //nested 布尔 true嵌套下级;false直接下级;默认false;
- listSubGroup: function(name, nested, async){
- getOrgActions();
- var data = {"groupList": getNameFlag(name)};
- var v = null;
- // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){
- // v = json.data;
- // return v;
- // }.ag().catch(function(json){ return json; });
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise;
- if (nested){
- promise = orgActions.listSubGroupNested(data, cb, null, !!async);
- }else{
- promise = orgActions.listSubGroupDirect(data, cb, null, !!async);
- }
- return (!!async) ? promise : v;
- // var v = null;
- // if (nested){
- // orgActions.listSubGroupNested(data, function(json){v = json.data;}, null, false);
- // }else{
- // orgActions.listSubGroupDirect(data, function(json){v = json.data;}, null, false);
- // }
- // return v;
- },
- //查询上级群组--返回群组的对象数组
- //nested 布尔 true嵌套上级;false直接上级;默认false;
- listSupGroup:function(name, nested, async){
- getOrgActions();
- var data = {"groupList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise
- if (nested){
- var promise = orgActions.listSupGroupNested(data, cb, null, !!async);
- }else{
- var promise = orgActions.listSupGroupDirect(data, cb, null, !!async);
- }
- return (!!async) ? promise : v;
- // var v = null;
- // if (nested){
- // orgActions.listSupGroupNested(data, function(json){v = json.data;}, null, false);
- // }else{
- // orgActions.listSupGroupDirect(data, function(json){v = json.data;}, null, false);
- // }
- // return v;
- },
- //人员所在群组(嵌套)--返回群组的对象数组
- listGroupWithPerson:function(name, async){
- getOrgActions();
- var data = {"personList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listGroupWithPerson(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var v = null;
- // orgActions.listGroupWithPerson(data, function(json){v = json.data;}, null, false);
- // return v;
- },
- //身份所在群组(嵌套)--返回群组的对象数组
- listGroupWithIdentity:function(identity, async){
- getOrgActions();
- var data = {"identityList": getNameFlag(identity)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listGroupWithIdentity(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //群组是否拥有角色--返回true, false
- groupHasRole: function(name, role, async){
- getOrgActions();
- nameFlag = (typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name;
- var data = {"group":nameFlag,"roleList":getNameFlag(role)};
- var v = false;
- var cb = function(json){
- v = json.data.value;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.groupHasRole(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var v = false;
- // orgActions.groupHasRole(data, function(json){v = json.data.value;}, null, false);
- // return v;
- },
- //角色***************
- //获取角色--返回角色的对象数组
- getRole: function(name, async){
- getOrgActions();
- var data = {"roleList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- v = (v && v.length===1) ? v[0] : v;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listRole(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var v = null;
- // orgActions.listRole(data, function(json){v = json.data;}, null, false);
- // return (v && v.length===1) ? v[0] : v;
- },
- //人员所有角色(嵌套)--返回角色的对象数组
- listRoleWithPerson:function(name, async){
- getOrgActions();
- var data = {"personList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listRoleWithPerson(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var v = null;
- // orgActions.listRoleWithPerson(data, function(json){v = json.data;}, null, false);
- // return v;
- },
- //人员***************
- //人员是否拥有角色--返回true, false
- personHasRole: function(name, role, async){
- getOrgActions();
- nameFlag = (typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name;
- var data = {"person":nameFlag,"roleList":getNameFlag(role)};
- var v = false;
- var cb = function(json){
- v = json.data.value;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.personHasRole(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var v = false;
- // orgActions.personHasRole(data, function(json){v = json.data.value;}, null, false);
- // return v;
- },
- //获取人员,附带身份,身份所在的组织,个人所在群组,个人拥有角色.
- getPersonData: function(name, async){
- getOrgActions();
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.getPerson(null, cb, null, !!async, {"flag": name});
- return (!!async) ? promise : v;
- },
- //获取人员--返回人员的对象数组
- getPerson: function(name, async, findCN){
- getOrgActions();
- var data = {"personList": getNameFlag(name)};
- if( o2.typeOf(findCN) === "boolean"){
- data.useNameFind = findCN;
- }
- var v = null;
- var cb = function(json){
- v = json.data;
- v = (v && v.length===1) ? v[0] : v;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPerson(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //查询下级人员--返回人员的对象数组
- //nested 布尔 true嵌套下级;false直接下级;默认false;
- listSubPerson: function(name, nested, async){
- getOrgActions();
- var data = {"personList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise;
- if (nested){
- promise = orgActions.listPersonSubNested(data, cb, null, !!async);
- }else{
- promise = orgActions.listPersonSubDirect(data, cb, null, !!async);
- }
- return (!!async) ? promise : v;
- },
- //查询上级人员--返回人员的对象数组
- //nested 布尔 true嵌套上级;false直接上级;默认false;
- listSupPerson: function(name, nested, async){
- getOrgActions();
- var data = {"personList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise;
- if (nested){
- promise = orgActions.listPersonSupNested(data, cb, null, !!async);
- }else{
- promise = orgActions.listPersonSupDirect(data, cb, null, !!async);
- }
- return (!!async) ? promise : v;
- },
- //获取群组的所有人员--返回人员的对象数组
- listPersonWithGroup: function(name, async){
- getOrgActions();
- var data = {"groupList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPersonWithGroup(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //获取角色的所有人员--返回人员的对象数组
- listPersonWithRole: function(name, async){
- getOrgActions();
- var data = {"roleList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise
- promise = orgActions.listPersonWithRole(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //获取身份的所有人员--返回人员的对象数组
- listPersonWithIdentity: function(name, async){
- getOrgActions();
- var data = {"identityList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPersonWithIdentity(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //获取身份的所有人员--返回人员的对象数组或人员对象
- getPersonWithIdentity: function(name, async){
- getOrgActions();
- var data = {"identityList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- v = (v && v.length===1) ? v[0] : v;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPersonWithIdentity(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //查询组织成员的人员--返回人员的对象数组
- //nested 布尔 true嵌套的所有成员;false直接成员;默认false;
- listPersonWithUnit: function(name, nested, async){
- getOrgActions();
- var data = {"unitList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise;
- if (nested){
- promise = orgActions.listPersonWithUnitNested(data, cb, null, !!async);
- }else{
- promise = orgActions.listPersonWithUnitDirect(data, cb, null, !!async);
- }
- return (!!async) ? promise : v;
- },
- //根据属性查询人员--返回人员的对象数组
- //name string 属性名
- //value string 属性值
- listPersonWithAttribute: function(name, value, async){
- getOrgActions();
- var data = {"name": name, "attribute": value};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPersonWithAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //根据属性查询人员--返回人员的全称数组
- //name string 属性名
- //value string 属性值
- listPersonNameWithAttribute: function(name, value, async){
- getOrgActions();
- var data = {"name": name, "attribute": value};
- var v = null;
- var cb = function(json){
- v = json.data.personList;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPersonWithAttributeValue(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //人员属性************
- //添加人员属性值(在属性中添加values值,如果没有此属性,则创建一个)
- appendPersonAttribute: function(person, attr, values, success, failure, async){
- getOrgActions();
- var personFlag = (typeOf(person)==="object") ? (person.distinguishedName || person.id || person.unique || person.name) : person;
- var data = {"attributeList":values,"name":attr,"person":personFlag};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.appendPersonAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- //orgActions.appendPersonAttribute(data, cb, null, !!async);
- },
- //设置人员属性值(将属性值修改为values,如果没有此属性,则创建一个)
- setPersonAttribute: function(person, attr, values, success, failure, async){
- getOrgActions();
- var personFlag = (typeOf(person)==="object") ? (person.distinguishedName || person.id || person.unique || person.name) : person;
- var data = {"attributeList":values,"name":attr,"person":personFlag};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.setPersonAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var cb = function(json){
- // if (success) return success(json);
- // }.ag().catch(function(xhr, text, error){
- // if (failure) return failure(xhr, text, error);
- // });
- //
- // orgActions.setPersonAttribute(data, cb, null, !!async);
- },
- //获取人员属性值
- getPersonAttribute: function(person, attr, async){
- getOrgActions();
- var personFlag = (typeOf(person)==="object") ? (person.distinguishedName || person.id || person.unique || person.name) : person;
- var data = {"name":attr,"person":personFlag};
- var v = null;
- var cb = function(json){
- v = json.data.attributeList;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.getPersonAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //列出人员所有属性的名称
- listPersonAttributeName: function(name, async){
- getOrgActions();
- var data = {"personList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data.nameList;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPersonAttributeName(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //列出人员的所有属性
- listPersonAllAttribute: function(name, async){
- getOrgActions();
- var data = {"personList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listPersonAllAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //身份**********
- //获取身份
- getIdentity: function(name, async){
- getOrgActions();
- var data = {"identityList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- v = (v && v.length===1) ? v[0] : v;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listIdentity(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //列出人员的身份
- listIdentityWithPerson: function(name, async, findCN){
- getOrgActions();
- var data = {"personList":getNameFlag(name)};
- if( o2.typeOf(findCN) === "boolean"){
- data.useNameFind = findCN;
- }
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listIdentityWithPerson(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //查询组织成员身份--返回身份的对象数组
- //nested 布尔 true嵌套的所有成员;false直接成员;默认false;
- listIdentityWithUnit: function(name, nested, async){
- getOrgActions();
- var data = {"unitList": getNameFlag(name)};
- var v = null;
- // var cb = function(json){
- // v = json.data;
- // if (async && o2.typeOf(async)=="function") return async(v);
- // return v;
- // }.ag().catch(function(json){ return json; });
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var method = (nested) ? "listIdentityWithUnitNested" : "listIdentityWithUnitDirect";
- var promise = orgActions[method](data, cb, null, !!async);
- promise.name = "org";
- //
- // if (nested){
- // orgActions.listIdentityWithUnitNested(data, cb, null, !!async);
- // }else{
- // orgActions.listIdentityWithUnitDirect(data, cb, null, !!async);
- // }
- return (!!async) ? promise : v;
- },
- //组织**********
- //获取组织
- getUnit: function(name, async, findCN){
- getOrgActions();
- var data = {"unitList":getNameFlag(name)};
- if( o2.typeOf(findCN) === "boolean"){
- data.useNameFind = findCN;
- }
- var v = null;
- var cb = function(json){
- v = json.data;
- v = (v && v.length===1) ? v[0] : v;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnit(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //查询组织的下级--返回组织的对象数组
- //nested 布尔 true嵌套下级;false直接下级;默认false;
- listSubUnit: function(name, nested, async){
- getOrgActions();
- var data = {"unitList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise;
- if (nested){
- promise = orgActions.listUnitSubNested(data, cb, null, !!async);
- }else{
- promise = orgActions.listUnitSubDirect(data, cb, null, !!async);
- }
- return (!!async) ? promise : v;
- },
- //查询组织的上级--返回组织的对象数组
- //nested 布尔 true嵌套上级;false直接上级;默认false;
- //async 布尔 true异步请求
- listSupUnit: function(name, nested, async){
- getOrgActions();
- var data = {"unitList": getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise;
- if (nested){
- promise = orgActions.listUnitSupNested(data, cb, null, !!async);
- }else{
- promise = orgActions.listUnitSupDirect(data, cb, null, !!async);
- }
- return (!!async) ? promise : v;
- // if (callback){
- // if (nested){
- // orgActions.listUnitSupNested(data, function(json){v = json.data; o2.runCallback(callback, "success", [v], this);});
- // }else{
- // orgActions.listUnitSupDirect(data, function(json){v = json.data; o2.runCallback(callback, "success", [v], this);});
- // }
- // }else{
- // var v = null;
- // if (nested){
- // orgActions.listUnitSupNested(data, function(json){v = json.data;}, null, false);
- // }else{
- // orgActions.listUnitSupDirect(data, function(json){v = json.data;}, null, false);
- // }
- // return v;
- // }
- },
- listSupUnitWithLevel: function(name, level, async){
- var v;
- var supUnitList = this.listSupUnit( name, true, !!async);
- var unitList = this.getUnit( name, false, !!async );
- var cb = function(sups, units){
- v = [].concat(
- sups,
- typeOf( units ) === "object" ? [units] : units
- ).filter(function (u){
- return u.level === level;
- });
- if (async && o2.typeOf(async)==="function") return async(v);
- return v;
- };
- if( typeof supUnitList.then === 'function' ){
- return Promise.all([supUnitList, unitList]).then(function( result){
- return cb(result[0], result[1]);
- });
- }else{
- return cb(supUnitList, unitList);
- }
- },
- listSupUnitWithType: function(name, type, async){
- var v;
- var supUnitList = this.listSupUnit( name, true, !!async);
- var unitList = this.getUnit( name, false, !!async );
- var cb = function(sups, units){
- v = [].concat(
- sups,
- typeOf( units ) === "object" ? [units] : units
- ).filter(function (u){
- return (u.typeList || []).contains( type );
- });
- if (async && o2.typeOf(async)==="function") return async(v);
- return v;
- };
- if( typeof supUnitList.then === 'function' ){
- return Promise.all([supUnitList, unitList]).then(function( result){
- return cb(result[0], result[1]);
- });
- }else{
- return cb(supUnitList, unitList);
- }
- },
- //根据个人身份获取组织
- //flag 数字 表示获取第几层的组织
- // 字符串 表示获取指定类型的组织
- // 空 表示获取直接所在的组织
- getUnitByIdentity: function(name, flag, async){
- getOrgActions();
- var getUnitMethod = "current";
- var v;
- if (flag){
- if (typeOf(flag)==="string") getUnitMethod = "type";
- if (typeOf(flag)==="number") getUnitMethod = "level";
- }
- var cb;
- var promise;
- switch (getUnitMethod){
- case "current":
- var data = {"identityList":getNameFlag(name)};
- // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){
- // v = json.data; v=(v&&v.length===1) ? v[0] : v; return v;
- // }.ag().catch(function(json){ return json; });
- cb = function(json){
- v = json.data; v=(v&&v.length===1) ? v[0] : v;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- promise = orgActions.listUnitWithIdentity(data, cb, null, !!async);
- break;
- case "type":
- var data = {"identity":(typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name,"type":flag};
- cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){
- // v = json.data; return v;
- // }.ag().catch(function(json){ return json; });
- promise = orgActions.getUnitWithIdentityAndType(data, cb, null, !!async);
- break;
- case "level":
- var data = {"identity":(typeOf(name)==="object") ? (name.distinguishedName || name.id || name.unique || name.name) : name,"level":flag};
- cb = function(json){
- v = json.data; v=(v&&v.length===1) ? v[0] : v;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- // var cb = ((async && o2.typeOf(async)=="function") ? (async.isAG ? async : async.ag()) : null) || function(json){
- // v = json.data; return v;
- // }.ag().catch(function(json){ return json; });
- promise = orgActions.getUnitWithIdentityAndLevel(data, cb, null, !!async);
- break;
- }
- return (!!async) ? promise : v;
- },
- //列出身份所在组织的所有上级组织
- listAllSupUnitWithIdentity: function(name, async){
- getOrgActions();
- var data = {"identityList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnitSupNestedWithIdentity(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //获取人员所在的所有组织
- listUnitWithPerson: function(name, async){
- getOrgActions();
- var data = {"personList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnitWithPerson(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //列出人员所在组织的所有上级组织
- listAllSupUnitWithPerson: function(name, async){
- getOrgActions();
- var data = {"personList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnitSupNestedWithPerson(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //根据组织属性,获取所有符合的组织
- listUnitWithAttribute: function(name, attribute, async){
- getOrgActions();
- var data = {"name":name,"attribute":attribute};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- promise = orgActions.listUnitWithAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //根据组织职务,获取所有符合的组织
- listUnitWithDuty: function(name, id, async){
- getOrgActions();
- var data = {"name":name,"identity":(typeOf(id)==="object") ? (id.distinguishedName || id.id || id.unique || id.name) : id};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnitWithDuty(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //组织职务***********
- //获取指定的组织职务的身份
- getDuty: function(duty, id, async){
- getOrgActions();
- var data = {"name":duty,"unit":(typeOf(id)==="object") ? (id.distinguishedName || id.id || id.unique || id.name) : id};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.getDuty(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //获取身份的所有职务名称
- listDutyNameWithIdentity: function(name, async){
- getOrgActions();
- var data = {"identityList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data.nameList;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listDutyNameWithIdentity(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //获取组织的所有职务名称
- listDutyNameWithUnit: function(name, async){
- getOrgActions();
- var data = {"unitList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data.nameList;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listDutyNameWithUnit(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //获取组织的所有职务
- listUnitAllDuty: function(name, async){
- getOrgActions();
- var data = {"unitList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnitAllDuty(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //列出顶层组织
- listTopUnit: function(async){
- var action = MWF.Actions.get("x_organization_assemble_control");
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = action.listTopUnit(cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //组织属性**************
- //添加组织属性值(在属性中添加values值,如果没有此属性,则创建一个)
- appendUnitAttribute: function(unit, attr, values, success, failure, async){
- getOrgActions();
- var unitFlag = (typeOf(unit)==="object") ? (unit.distinguishedName || unit.id || unit.unique || unit.name) : unit;
- var data = {"attributeList":values,"name":attr,"unit":unitFlag};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.appendUnitAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var cb = function(json){
- // if (success) return success(json);
- // }.ag().catch(function(xhr, text, error){
- // if (failure) return failure(xhr, text, error);
- // });
- //
- // orgActions.appendPersonAttribute(data, cb, null, !!async);
- // orgActions.appendUnitAttribute(data, function(json){
- // if (json.data.value){
- // if (success) success();
- // }else{
- // if (failure) failure(null, "", "append values failed");
- // }
- // }, function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // }, false);
- },
- //设置组织属性值(将属性值修改为values,如果没有此属性,则创建一个)
- setUnitAttribute: function(unit, attr, values, success, failure, async){
- getOrgActions();
- var unitFlag = (typeOf(unit)==="object") ? (unit.distinguishedName || unit.id || unit.unique || unit.name) : unit;
- var data = {"attributeList":values,"name":attr,"unit":unitFlag};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.setUnitAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- // var cb = function(json){
- // if (success) return success(json);
- // }.ag().catch(function(xhr, text, error){
- // if (failure) return failure(xhr, text, error);
- // });
- // orgActions.setUnitAttribute(data, cb, null, !!async);
- // orgActions.setUnitAttribute(data, function(json){
- // if (json.data.value){
- // if (success) success();
- // }else{
- // if (failure) failure(null, "", "append values failed");
- // }
- // }, function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // }, false);
- },
- //获取组织属性值
- getUnitAttribute: function(unit, attr, async){
- getOrgActions();
- var unitFlag = (typeOf(unit)==="object") ? (unit.distinguishedName || unit.id || unit.unique || unit.name) : unit;
- var data = {"name":attr,"unit":unitFlag};
- var v = null;
- var cb = function(json){
- v = json.data.attributeList;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.getUnitAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //列出组织所有属性的名称
- listUnitAttributeName: function(name, async){
- getOrgActions();
- var data = {"unitList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data.nameList;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnitAttributeName(data, cb, null, !!async);
- return (!!async) ? promise : v;
- },
- //列出组织的所有属性
- listUnitAllAttribute: function(name, async){
- getOrgActions();
- var data = {"unitList":getNameFlag(name)};
- var v = null;
- var cb = function(json){
- v = json.data;
- if (async && o2.typeOf(async)=="function") return async(v);
- return v;
- };
- var promise = orgActions.listUnitAllAttribute(data, cb, null, !!async);
- return (!!async) ? promise : v;
- }
- };
- this.Action = (function(){
- var actions = [];
- return function(root, json){
- var action = actions[root] || (actions[root] = new MWF.xDesktop.Actions.RestActions("", root, ""));
- action.getActions = function(callback){
- if (!this.actions) this.actions = {};
- Object.merge(this.actions, json);
- if (callback) callback();
- };
- this.invoke = function(option){
- action.invoke(option)
- }
- }
- })();
- // this.service = {
- // "jaxwsClient":{},
- // "jaxrsClient":{}
- // };
- var lookupAction = null;
- var getLookupAction = function(callback){
- if (!lookupAction){
- MWF.require("MWF.xDesktop.Actions.RestActions", function(){
- lookupAction = new MWF.xDesktop.Actions.RestActions("", "x_processplatform_assemble_surface", "");
- lookupAction.getActions = function(actionCallback){
- this.actions = {
- //"lookup": {"uri": "/jaxrs/view/flag/{view}/application/flag/{application}"},
- //"getView": {"uri": "/jaxrs/view/{id}/design"}
- "lookup": {"uri": "/jaxrs/queryview/flag/{view}/application/flag/{application}/execute", "method":"PUT"},
- "getView": {"uri": "/jaxrs/queryview/flag/{view}/application/flag/{application}"}
- };
- if (actionCallback) actionCallback();
- };
- if (callback) callback();
- });
- }else{
- if (callback) callback();
- }
- };
- this.view = {
- "lookup": function(view, callback, async){
- var filterList = {"filterList": (view.filter || null)};
- return MWF.Actions.load("x_query_assemble_surface").ViewAction.executeWithQuery(view.view, view.application, filterList, function(json){
- var data = {
- "grid": json.data.grid || json.data.groupGrid,
- "groupGrid": json.data.groupGrid
- };
- if (callback) callback(data);
- return data;
- }, null, async);
- },
- "lookupV1": function(view, callback){
- getLookupAction(function(){
- lookupAction.invoke({"name": "lookup","async": true, "parameter": {"view": view.view, "application": view.application},"success": function(json){
- var data = {
- "grid": json.data.grid,
- "groupGrid": json.data.groupGrid
- };
- if (callback) callback(data);
- }.bind(this)});
- }.bind(this));
- },
- "select": function(view, callback, options){
- if (view.view){
- var viewJson = {
- "application": view.application || _form.json.application,
- "viewName": view.view || "",
- "isTitle": (view.isTitle===false) ? "no" : "yes",
- "select": (view.isMulti===false) ? "single" : "multi",
- "filter": view.filter
- };
- if (!options) options = {};
- options.width = view.width;
- options.height = view.height;
- options.title = view.caption;
- var width = options.width || "700";
- var height = options.height || "400";
- if (layout.mobile){
- var size = document.body.getSize();
- width = size.x;
- height = size.y;
- options.style = "viewmobile";
- }
- width = width.toInt();
- height = height.toInt();
- var size = _form.app.content.getSize();
- var x = (size.x-width)/2;
- var y = (size.y-height)/2;
- if (x<0) x = 0;
- if (y<0) y = 0;
- if (layout.mobile){
- x = 20;
- y = 0;
- }
- var _self = this;
- MWF.require("MWF.xDesktop.Dialog", function(){
- var dlg = new MWF.xDesktop.Dialog({
- "title": options.title || "select view",
- "style": options.style || "view",
- "top": y,
- "left": x-20,
- "fromTop":y,
- "fromLeft": x-20,
- "width": width,
- "height": height,
- "html": "<div style='height: 100%;'></div>",
- "maskNode": _form.app.content,
- "container": _form.app.content,
- "buttonList": [
- {
- "text": MWF.LP.process.button.ok,
- "action": function(){
- //if (callback) callback(_self.view.selectedItems);
- if (callback) callback(_self.view.getData());
- this.close();
- }
- },
- {
- "text": MWF.LP.process.button.cancel,
- "action": function(){this.close();}
- }
- ]
- });
- dlg.show();
- if (layout.mobile){
- var backAction = dlg.node.getElement(".MWF_dialod_Action_back");
- var okAction = dlg.node.getElement(".MWF_dialod_Action_ok");
- if (backAction) backAction.addEvent("click", function(e){
- dlg.close();
- }.bind(this));
- if (okAction) okAction.addEvent("click", function(e){
- //if (callback) callback(this.view.selectedItems);
- if (callback) callback(this.view.getData());
- dlg.close();
- }.bind(this));
- }
- MWF.xDesktop.requireApp("query.Query", "Viewer", function(){
- this.view = new MWF.xApplication.query.Query.Viewer(dlg.content.getFirst(), viewJson, {"style": "select"}, _form.app, _form.Macro);
- }.bind(this));
- }.bind(this));
- }
- }
- };
- this.statement = {
- execute: function (obj, callback, async) {
- if( obj.format ){
- return this._execute(obj, callback, async, obj.format);
- }else{
- if( this.needCheckFormat(obj) ){
- var result;
- var p = MWF.Actions.load("x_query_assemble_surface").StatementAction.getFormat(obj.name, function(json){
- result = this._execute(obj, callback, async, json.data.format);
- return result;
- }.bind(this), null, async);
- return result || p;
- }else{
- return this._execute(obj, callback, async, "");
- }
- }
- },
- needCheckFormat: function(s){
- if( s.format )return false;
- if( typeOf(s.parameter) === "object" ){
- for( var p in s.parameter ){
- if( typeOf( s.parameter[p] ) === "date" )return true;
- }
- }
- if( typeOf(s.filter) === "array" ){
- for( var i=0; i< s.filter.length; i++){
- var fType = s.filter[i].formatType;
- if( ["dateTimeValue", "datetimeValue", "dateValue", "timeValue"].contains( fType ) )return true;
- }
- }
- return false;
- },
- _execute: function(statement, callback, async, format){
- var parameter = this.parseParameter(statement.parameter, format);
- var filterList = this.parseFilter(statement.filter, parameter, format);
- var obj = {
- "filterList": filterList,
- "parameter" : parameter
- };
- return MWF.Actions.load("x_query_assemble_surface").StatementAction.executeV2(
- statement.name, statement.mode || "data", statement.page || 1, statement.pageSize || 20, obj,
- function (json) {
- if (callback) callback(json);
- return json;
- }, null, async);
- },
- parseFilter : function( filter, parameter , format){
- if( typeOf(filter) !== "array" )return [];
- if( !parameter )parameter = {};
- var filterList = [];
- ( filter || [] ).each( function (d) {
- if( !d.logic )d.logic = "and";
- //var parameterName = d.path.replace(/\./g, "_");
- var pName = d.path.replace(/\./g, "_");
- var parameterName = pName;
- var suffix = 1;
- while( parameter[parameterName] ){
- parameterName = pName + "_" + suffix;
- suffix++;
- }
- var value = d.value;
- if( d.comparison === "like" || d.comparison === "notLike" ){
- if( value.substr(0, 1) !== "%" )value = "%"+value;
- if( value.substr(value.length-1,1) !== "%" )value = value+"%";
- parameter[ parameterName ] = value; //"%"+value+"%";
- }else{
- if( ["sql", "sqlScript"].contains(format) ) {
- if (d.formatType === "numberValue") {
- value = parseFloat(value);
- }
- }else{
- if (d.formatType === "dateTimeValue" || d.formatType === "datetimeValue") {
- value = "{ts '" + value + "'}"
- } else if (d.formatType === "dateValue") {
- value = "{d '" + value + "'}"
- } else if (d.formatType === "timeValue") {
- value = "{t '" + value + "'}"
- } else if (d.formatType === "numberValue") {
- value = parseFloat(value);
- }
- }
- parameter[ parameterName ] = value;
- }
- d.value = parameterName;
- filterList.push( d );
- }.bind(this));
- return filterList;
- },
- parseParameter : function( obj, format ){
- if( typeOf(obj) !== "object" )return {};
- var parameter = {};
- //传入的参数
- for( var p in obj ){
- var value = obj[p];
- if( typeOf( value ) === "date" ){
- if( ["sql", "sqlScript"].contains(format) ){
- value = value.format("db");
- }else{
- value = "{ts '"+value.format("db")+"'}"
- }
- }
- parameter[ p ] = value;
- }
- return parameter;
- },
- "select": function (statement, callback, options) {
- if (statement.name) {
- // var parameter = this.parseParameter(statement.parameter);
- // var filterList = this.parseFilter(statement.filter, parameter);
- var statementJson = {
- "statementId": statement.name || "",
- "isTitle": (statement.isTitle === false) ? "no" : "yes",
- "select": (statement.isMulti === false) ? "single" : "multi",
- "filter": statement.filter,
- "parameter": statement.parameter
- };
- if (!options) options = {};
- options.width = statement.width;
- options.height = statement.height;
- options.title = statement.caption;
- var width = options.width || "700";
- var height = options.height || "400";
- if (layout.mobile) {
- var size = document.body.getSize();
- width = size.x;
- height = size.y;
- options.style = "viewmobile";
- }
- width = width.toInt();
- height = height.toInt();
- var size = _form.app.content.getSize();
- var x = (size.x - width) / 2;
- var y = (size.y - height) / 2;
- if (x < 0) x = 0;
- if (y < 0) y = 0;
- if (layout.mobile) {
- x = 20;
- y = 0;
- }
- var _self = this;
- MWF.require("MWF.xDesktop.Dialog", function () {
- var dlg = new MWF.xDesktop.Dialog({
- "title": options.title || "select statement view",
- "style": options.style || "view",
- "top": y,
- "left": x - 20,
- "fromTop": y,
- "fromLeft": x - 20,
- "width": width,
- "height": height,
- "html": "<div style='height: 100%;'></div>",
- "maskNode": _form.app.content,
- "container": _form.app.content,
- "buttonList": [
- {
- "text": MWF.LP.process.button.ok,
- "action": function () {
- //if (callback) callback(_self.view.selectedItems);
- if (callback) callback(_self.statement.getData());
- this.close();
- }
- },
- {
- "text": MWF.LP.process.button.cancel,
- "action": function () { this.close(); }
- }
- ]
- });
- dlg.show();
- if (layout.mobile) {
- var backAction = dlg.node.getElement(".MWF_dialod_Action_back");
- var okAction = dlg.node.getElement(".MWF_dialod_Action_ok");
- if (backAction) backAction.addEvent("click", function (e) {
- dlg.close();
- }.bind(this));
- if (okAction) okAction.addEvent("click", function (e) {
- //if (callback) callback(this.view.selectedItems);
- if (callback) callback(this.statement.getData());
- dlg.close();
- }.bind(this));
- }
- MWF.xDesktop.requireApp("query.Query", "Statement", function () {
- this.statement = new MWF.xApplication.query.Query.Statement(dlg.content.getFirst(), statementJson, { "style": "select" }, _form.app, _form.Macro);
- }.bind(this));
- }.bind(this));
- }
- }
- };
- this.importer = {
- "upload": function (options, callback, async) {
- MWF.xDesktop.requireApp("query.Query", "Importer", function () {
- var importer = new MWF.xApplication.query.Query.Importer(_form.app.content, options, {}, _form.app, _form.Macro);
- importer.addEvent("afterImport", function (data) {
- if(callback)callback(data);
- });
- importer.load();
- }.bind(this));
- },
- "downloadTemplate": function(options, fileName, callback){
- MWF.xDesktop.requireApp("query.Query", "Importer", function () {
- var importer = new MWF.xApplication.query.Query.Importer(_form.app.content, options, {}, _form.app, _form.Macro);
- importer.downloadTemplate(fileName, callback);
- }.bind(this));
- }
- };
- //include 引用脚本
- //optionsOrName : {
- // type : "", 默认为process, 可以为 portal process cms
- // application : "", 门户/流程/CMS的名称/别名/id, 默认为当前应用
- // name : "" // 脚本名称/别名/id
- //}
- //或者name: "" // 脚本名称/别名/id
- // if( !window.includedScripts ){
- // var includedScripts = window.includedScripts = [];
- // }else{
- // var includedScripts = window.includedScripts;
- // }
- /**
- * 在流程、门户、内容管理或服务管理中可以创建了脚本配置。</br>
- * 默认情况下系统以javascript格式进行编辑。
- * 这个时候可以使用<code class='language-js'>this.include()</code>引用脚本配置。</br>
- * 在v9.2以后,如果脚本配置名称以.json 、 .html 或 .css结束,系统会加载相应的编辑器。
- * 这种情况您可以使用如下方法获取内容。
- * <pre><code class='language-js'>this.includeHmtl();
- * this.includeCss();
- * this.includeJson();
- * </code></pre>
- * @module include
- * @o2cn 脚本配置相应api
- * @o2category web
- * @o2ordernumber 140
- */
- /**
- * this.include是一个方法,当您在流程、门户、内容管理或服务管理中创建了脚本配置,可以使用this.include()用来引用脚本配置。<br/>
- * v8.0及以后版本中增加了服务管理的脚本配置。<br/>
- * <b>(建议使用表单中的预加载脚本,需要判断加载的时候才使用本方法加载脚本,此时建议异步加载有助于表单加载速度。)</b><br/>
- * @method include
- * @methodOf module:include
- * @param {(String|Object|String[]|Object[])} optionsOrName 可以是脚本标识字符串(数组)或者是对象(数组)。
- * <pre><code class='language-js'>
- * //如果需要引用本应用的脚本配置,将options设置为String或者String Array。
- * this.include("initScript") //脚本配置的名称、别名或id
- * this.include(["initScript","initScript2"]) //可以是字符串数组
- *
- * //如果需要引用其他应用的脚本配置,将options设置为Object或者Object Array;
- * this.include({
- * //type: 应用类型。可以为 portal process cms service。
- * //如果没有该选项或者值为空字符串,则表示应用脚本和被应用的脚本配置类型相同。
- * //比如在门户的A应用脚本中引用门户B应用的脚本配置,则type可以省略。
- * type : "portal",
- * application : "首页", // 门户、流程、CMS的名称、别名、id。 默认为当前应用,如果脚本在服务管理中忽略该参数
- * name : "initScript" // 脚本配置的名称、别名或id
- * })
- * this.include([ //也可以对象和字符串混合数组
- * {
- * type : "portal",
- * application : "首页",
- * name : "initScript"
- * },
- * "initScript2"
- * ])
- *
- * //引用服务管理中的脚本
- * this.include({
- * "type": "service",
- * "name": "scriptName"
- * });
- *
- * //引用流程管理中的脚本
- * this.include({
- * "type": "process",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //引用内容管理中的脚本
- * this.include({
- * "type": "cms",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //引用门户管理中的脚本
- * this.include({
- * "type": "portal",
- * "application": "appName",
- * "name": "scriptName"
- * });
- * </code></pre>
- * @param {Function} [callback] 加载后执行的回调方法
- * @param {Boolean} [async] 是否异步加载
- * @o2syntax
- * //您可以在表单、流程、视图和查询视图的各个嵌入脚本中,通过this.include()来引用本应用或其他应用的脚本配置,如下:
- * this.include( optionsOrName, callback, async )
- * @example
- * <caption>
- * <b>样例一:</b>在通用脚本中定义返回当前人员名称的方法,在各个门户应用都使用这个方法显示人员名称。<br/>
- * 1、在门户应用中有一个commonApp的应用,在该应用中创建一个脚本,命名为initScript,并定义方法。
- * <img src='img/module/include/define1.png' />
- * </caption>
- * //定义一个方法
- * this.define("getUserName", function(){
- * return ( layout.desktop.session.user || layout.user ).name
- * }.bind(this))
- * @example
- * <caption>
- * 2、在门户页面中添加事件'queryLoad',在事件中引入 initScript 脚本配置。
- * <img src='img/module/include/define2.png' style='max-width:700px;'/>
- * </caption>
- * this.include({
- * type : "portal",
- * application : "commonApp",
- * name : "initScript"
- * })
- *
- * @example
- * <caption>
- * 3、在门户页面的'load'事件中使用方法。<br/>
- * <img src='img/module/include/define3.png' style='max-width:700px;'/>
- * </caption>
- * var userNameNode = this.page.get("userName").node; //获取Dom对象
- * var urerName = this.getUserName(); //使用initScript脚本中的方法
- * userNameNode.set("text", urerName ); //为DOM对象设置值
- */
- /**
- * 当脚本配置保存的是html文件(名称以.html结束),this.includeHtml可以以获取html内容。
- * @method includeHtml
- * @since v9.2
- * @methodOf module:include
- * @param {(String|Object)} optionsOrName 可以是脚本标识字符串或者是对象。
- * <pre><code class='language-js'>
- * //如果需要获取本应用的html(在脚本配置中),将options设置为String。
- * this.includeHtml("test.html") //脚本配置的名称、别名或id
- *
- * //如果需要获取其他应用的html,将options设置为Object;
- * this.includeHtml({
- * //type: 应用类型。可以为 portal process cms service。
- * //如果没有该选项或者值为空字符串,则表示应用脚本和被应用的脚本配置类型相同。
- * //比如在门户的A应用脚本中引用门户B应用的脚本配置,则type可以省略。
- * type : "portal",
- * application : "首页", // 门户、流程、CMS的名称、别名、id。 默认为当前应用,如果脚本在服务管理中忽略该参数
- * name : "test.html" // 脚本配置的名称、别名或id
- * })
- *
- * //获取服务管理中的html
- * this.includeHtml({
- * "type": "service",
- * "name": "scriptName"
- * });
- *
- * //获取流程管理中的html
- * this.includeHtml({
- * "type": "process",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //获取内容管理中的html
- * this.includeHtml({
- * "type": "cms",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //获取门户管理中的html
- * this.includeHtml({
- * "type": "portal",
- * "application": "appName",
- * "name": "scriptName"
- * });
- * </code></pre>
- * @param {Function} [callback] 加载后执行的回调方法
- * @param {Boolean} [async] 是否异步加载,默认为true
- * @o2syntax
- * this.includeHtml( optionsOrName, callback, async )
- * @example
- * //使用promise获取html
- * //在本应用的脚本库里配置了html,名称为test.html
- * var promise = this.includeHtml("test.html");
- * promise.then(function(html){
- * //假设表单上有一个容器,标识为div
- * var div = this.form.get('div').node;
- * //将html渲染在div节点上,可以查看 api o2.loadHtmlText
- * o2.loadHtmlText(html, {dom: div})
- * }.bind(this))
- * @example
- * //在回调中获取html
- * //在本应用的脚本库里配置了html,名称为test.html
- * this.includeHtml("test.html", function(html){
- * //假设表单上有一个容器,标识为div
- * var div = this.form.get('div').node;
- * //将html渲染在div节点上,可以查看 api o2.loadHtmlText
- * o2.loadHtmlText(html, {dom: div})
- * }.bind(this))
- * @example
- * //同步获取html(不推荐)
- * //在门户的脚本库里配置了html,名称为test.html
- * var html = this.includeHtml({
- * "type": "portal",
- * "application": "appName", //门户的标识
- * "name": "test.html"
- * }, null, false);
- * var div = this.form.get('div').node; //假设表单/页面上有一个容器,标识为div
- * div.set('html', html); //将html渲染在div节点上
- */
- /**
- * 当脚本配置保存的是css文件(名称以.css结束),this.includeCss可以以获取html内容。
- * @method includeCss
- * @since v9.2
- * @methodOf module:include
- * @param {(String|Object)} optionsOrName 可以是脚本标识字符串或者是对象。
- * <pre><code class='language-js'>
- * //如果需要获取本应用的css(在脚本配置中),将options设置为String。
- * this.includeCss("test.css") //脚本配置的名称、别名或id
- *
- * //如果需要获取其他应用的html,将options设置为Object;
- * this.includeCss({
- * //type: 应用类型。可以为 portal process cms service。
- * //如果没有该选项或者值为空字符串,则表示应用脚本和被应用的脚本配置类型相同。
- * //比如在门户的A应用脚本中引用门户B应用的脚本配置,则type可以省略。
- * type : "portal",
- * application : "首页", // 门户、流程、CMS的名称、别名、id。 默认为当前应用,如果脚本在服务管理中忽略该参数
- * name : "initScript" // 脚本配置的名称、别名或id
- * })
- *
- * //获取服务管理中的html
- * this.includeCss({
- * "type": "service",
- * "name": "scriptName"
- * });
- *
- * //获取流程管理中的html
- * this.includeCss({
- * "type": "process",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //获取内容管理中的html
- * this.includeCss({
- * "type": "cms",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //获取门户管理中的html
- * this.includeCss({
- * "type": "portal",
- * "application": "appName",
- * "name": "scriptName"
- * });
- * </code></pre>
- * @param {Function} [callback] 加载后执行的回调方法
- * @param {Boolean} [async] 是否异步加载,默认为true
- * @o2syntax
- * this.includeCss( optionsOrName, callback, async )
- * @example
- * //使用promise获取css文本
- * //在本应用的脚本库里配置了css,名称为test.css
- * var promise = this.includeCss("test.css");
- * promise.then(function(cssText){
- * //将css作用在表单/页面上,具体可以查看 api: o2.loadCssText
- * var node = this.form.getApp().content;
- * o2.loadCssText(cssText, {dom: node})
- * }.bind(this))
- * @example
- * //在回调中获取css文本
- * //在本应用的脚本库里配置了css,名称为test.css
- * this.includeCss("test.css", function(cssText){
- * o2.loadCssText(cssText, {dom: document.body}) //把css作为全局渲染
- * }.bind(this))
- * @example
- * //同步获取css文本(不推荐)
- * //在门户的脚本库里配置了css,名称为test.css
- * var cssText = this.includeCss({
- * "type": "portal",
- * "application": "appName", //门户的标识
- * "name": "test.css"
- * }, null, false);
- * var node = this.form.getApp().content;
- * o2.loadCssText(cssText, {dom: node})
- */
- /**
- * 当脚本配置保存的是json文件(名称以.json结束),this.includeJson可以以获取json内容。
- * @method includeJson
- * @since v9.2
- * @methodOf module:include
- * @param {(String|Object)} optionsOrName 可以是脚本标识字符串或者是对象。
- * <pre><code class='language-js'>
- * //如果需要获取本应用的json(在脚本配置中),将options设置为String。
- * this.includeJson("test.json") //脚本配置的名称、别名或id
- *
- * //如果需要获取其他应用的html,将options设置为Object;
- * this.includeJson({
- * //type: 应用类型。可以为 portal process cms service。
- * //如果没有该选项或者值为空字符串,则表示应用脚本和被应用的脚本配置类型相同。
- * //比如在门户的A应用脚本中引用门户B应用的脚本配置,则type可以省略。
- * type : "portal",
- * application : "首页", // 门户、流程、CMS的名称、别名、id。 默认为当前应用,如果脚本在服务管理中忽略该参数
- * name : "initScript" // 脚本配置的名称、别名或id
- * })
- *
- * //获取服务管理中的json对象
- * this.includeJson({
- * "type": "service",
- * "name": "scriptName"
- * });
- *
- * //获取流程管理中的json对象
- * this.includeJson({
- * "type": "process",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //获取内容管理中的json对象
- * this.includeJson({
- * "type": "cms",
- * "application": "appName",
- * "name": "scriptName"
- * });
- *
- * //获取门户管理中的json对象
- * this.includeJson({
- * "type": "portal",
- * "application": "appName",
- * "name": "scriptName"
- * });
- * </code></pre>
- * @param {Function} [callback] 加载后执行的回调方法
- * @param {Boolean} [async] 是否异步加载,默认为true
- * @o2syntax
- * this.includeJson( optionsOrName, callback, async )
- * @example
- * //使用promise获取json数据
- * //在本应用的脚本库里配置了json,名称为test.json
- * var promise = this.includeJson("test.json");
- * promise.then(function(json){
- * //json为获取的数据
- * }.bind(this))
- * @example
- * //在回调中获取json数据
- * //在本应用的脚本库里配置了json,名称为test.json
- * this.includeJson("test.json", function(json){
- * //json为获取的数据
- * }.bind(this))
- * @example
- * //同步获取json数据(不推荐)
- * //在门户的脚本库里配置了css,名称为test.json
- * var json = this.includeJson({
- * "type": "portal",
- * "application": "appName", //门户的标识
- * "name": "test.json"
- * }, null, false);
- */
- var _getScriptAction = function ( type ){
- var scriptAction;
- switch (type) {
- case "portal" :
- if (this.scriptActionPortal) {
- scriptAction = this.scriptActionPortal;
- } else {
- MWF.require("MWF.xScript.Actions.PortalScriptActions", null, false);
- scriptAction = this.scriptActionPortal = new MWF.xScript.Actions.PortalScriptActions();
- }
- break;
- case "process" :
- if (this.scriptActionProcess) {
- scriptAction = this.scriptActionProcess;
- } else {
- MWF.require("MWF.xScript.Actions.ScriptActions", null, false);
- scriptAction = this.scriptActionProcess = new MWF.xScript.Actions.ScriptActions();
- }
- break;
- case "cms" :
- if (this.scriptActionCMS) {
- scriptAction = this.scriptActionCMS;
- } else {
- MWF.require("MWF.xScript.Actions.CMSScriptActions", null, false);
- scriptAction = this.scriptActionCMS = new MWF.xScript.Actions.CMSScriptActions();
- }
- break;
- case "service" :
- if (this.scriptActionService) {
- scriptAction = this.scriptActionService;
- } else {
- MWF.require("MWF.xScript.Actions.ServiceScriptActions", null, false);
- scriptAction = this.scriptActionService = new MWF.xScript.Actions.ServiceScriptActions();
- }
- break;
- }
- return scriptAction;
- }
- //缓存名称、别名、id
- var _parseScriptImportList = function (json, type){
- var includedScripts = [];
- var importedList = json.data.importedList || [];
- importedList.each(function (flag) {
- if (type === "portal") {
- includedScripts.push(type + "-" + json.data.portal + "-" + flag);
- if (json.data.portalName) includedScripts.push(type + "-" + json.data.portalName + "-" + flag);
- if (json.data.portalAlias) includedScripts.push(type + "-" + json.data.portalAlias + "-" + flag);
- } else if (type === "cms") {
- includedScripts.push(type + "-" + json.data.appId + "-" + flag);
- if (json.data.appName) includedScripts.push(type + "-" + json.data.appName + "-" + flag);
- if (json.data.appAlias) includedScripts.push(type + "-" + json.data.appAlias + "-" + flag);
- } else if (type === "process") {
- includedScripts.push(type + "-" + json.data.application + "-" + flag);
- if (json.data.appName) includedScripts.push(type + "-" + json.data.appName + "-" + flag);
- if (json.data.appAlias) includedScripts.push(type + "-" + json.data.appAlias + "-" + flag);
- }else if (type === "service") {
- includedScripts.push(type + "-" + flag);
- }
- });
- return includedScripts.concat(importedList);
- }
- var includedScripts = [];
- var _includeSingle = function( optionsOrName , callback, async){
- var options = optionsOrName;
- if( typeOf( options ) === "string" ){
- options = { name : options };
- }
- var name = options.name;
- var type;
- if( options.type === "service" ){
- type = options.type;
- }else{
- type = ( options.type && options.application ) ? options.type : "process";
- }
- var application = options.application || _form.json.application;
- var key = type +"-" + application + "-" + name;
- if( type === "service" ){
- key = type + "-" + name;
- }
- //js 加载过就不重新加载了
- if (includedScripts.indexOf( key )> -1){
- if (callback) callback.apply(this);
- return;
- }
- var successCallback = function (json) {
- if (json.data) {
- includedScripts.push(key);
- includedScripts = includedScripts.concat( _parseScriptImportList(json, type) );
- if( (options.enableAnonymous || options.anonymous ) && type === "cms" ){
- MWF.CMSMacro.exec(json.data.text, this)
- }else{
- MWF.Macro.exec(json.data.text, this);
- }
- if (callback) callback.apply(this);
- } else {
- if (callback) callback.apply(this);
- }
- }.bind(this);
- if (( options.enableAnonymous || options.anonymous ) && type === "cms") {
- o2.Actions.load("x_cms_assemble_control").ScriptAnonymousAction.getWithAppWithName(application, name, successCallback, null, !!async);
- } else {
- var scriptAction = _getScriptAction.call(this, type);
- if( type === "service" ){
- scriptAction.getScriptByName(name, includedScripts, successCallback, null, !!async);
- }else{
- scriptAction.getScriptByName(application, name, includedScripts, successCallback, null, !!async);
- }
- }
- };
- this.include = function( optionsOrName , callback, async){
- if (o2.typeOf(optionsOrName)==="array"){
- if (!!async){
- var count = optionsOrName.length;
- var loaded = 0;
- optionsOrName.each(function(option){
- _includeSingle.apply(this, [option, function(){
- loaded++;
- if (loaded>=count) if (callback) callback.apply(this);
- }.bind(this), true]);
- }.bind(this));
- }else{
- optionsOrName.each(function(option){
- _includeSingle.apply(this, [option]);
- }.bind(this));
- if (callback) callback.apply(this);
- }
- }else{
- _includeSingle.apply(this, [optionsOrName , callback, async])
- }
- };
- var includedSourceMap = {};
- var _includeSource = function (optionsOrName, callback, async, fileType) {
- var options = typeOf(optionsOrName) === "string" ? {name: optionsOrName} : optionsOrName;
- var name = options.name;
- var type = options.type === "service" ? options.type : ((options.type && options.application) ? options.type : "portal");
- var application = options.application || _form.json.application;
- var key = type === "service" ? (type + "-" + name) : (type + "-" + application + "-" + name);
- var data, result;
- if( includedSourceMap[key] ){
- data = includedSourceMap[key];
- if(callback)callback( data.text );
- return !!async ? Promise.resolve( data.text ) : data.text;
- }
- var successCallback = function (json) {
- if (json.data) {
- var includeds = [key];
- includeds = includeds.concat( _parseScriptImportList(json, type) );
- includeds.each(function(k){
- includedSourceMap[k] = json.data;
- })
- result = json.data.text;
- if( fileType === 'json' ){
- result = JSON.parse(result);
- }
- if (callback) callback.call(this, result);
- } else {
- result = '';
- if (callback) callback.call(this, '');
- }
- return result;
- }.bind(this);
- var p;
- if (( options.enableAnonymous || options.anonymous ) && type === "cms") {
- p = o2.Actions.load("x_cms_assemble_control").ScriptAnonymousAction.getWithAppWithName(application, name, !!async ? null : successCallback, null, !!async);
- } else {
- var scriptAction = _getScriptAction.call(this, type);
- if( type === "service" ){
- p = scriptAction.getScriptByName(name, includedScripts, successCallback, !!async ? null : successCallback, null, !!async);
- }else{
- p = scriptAction.getScriptByName(application, name, includedScripts, !!async ? null : successCallback, null, !!async);
- }
- }
- return !!async ? p.then( successCallback ) : result;
- };
- this.includeHtml = function (optionsOrName, callback, async){
- return _includeSource.apply(this, [optionsOrName, callback, async!==false, 'html'])
- };
- this.includeJson = function (optionsOrName, callback, async){
- return _includeSource.apply(this, [optionsOrName, callback, async!==false, 'json'])
- };
- this.includeCss = function (optionsOrName, callback, async){
- return _includeSource.apply(this, [optionsOrName, callback, async!==false, 'css']);
- };
- /**
- * this.define是一个方法,您可以在流程、门户或者内容管理中创建脚本配置,在脚本配置中您可以通过this.define()来定义自己的方法。<br/>
- * 通过这种方式定义方法,在不同的应用使用相同的方法名称也不会造成冲突。
- * @module define
- * @o2cn 方法定义
- * @o2category web
- * @o2ordernumber 150
- * @param {(String)} name 定义的方法名称。
- * @param {Function} fun 定义的方法
- * @param {Boolean} [overwrite] 定义的方法是否能被覆盖重写。默认值为true。
- * @o2syntax
- * this.define(name, fun, overwrite)
- * @example
- * <caption>
- * <b>样例:</b>在通用脚本中定义返回当前人员名称的方法,在各个门户应用都使用这个方法显示人员名称。<br/>
- * 1、在门户应用中有一个commonApp的应用,在该应用中创建一个脚本,命名为initScript,并定义方法。
- * <img src='img/module/include/define1.png' />
- * </caption>
- * //定义一个方法
- * this.define("getUserName", function(){
- * return ( layout.desktop.session.user || layout.user ).name
- * }.bind(this))
- * @example
- * <caption>
- * 2、在门户页面中添加事件'queryLoad',在事件中引入 initScript 脚本配置。
- * <img src='img/module/include/define2.png' style='max-width:700px;'/>
- * </caption>
- * this.include({
- * type : "portal",
- * application : "commonApp",
- * name : "initScript"
- * })
- *
- * @example
- * <caption>
- * 3、在门户页面的'load'事件中使用方法。<br/>
- * <img src='img/module/include/define3.png' style='max-width:700px;'/>
- * </caption>
- * var userNameNode = this.page.get("userName").node; //获取Dom对象
- * var urerName = this.getUserName(); //使用initScript脚本中的方法
- * userNameNode.set("text", urerName ); //为DOM对象设置值
- */
- this.define = function(name, fun, overwrite){
- var over = true;
- if (overwrite===false) over = false;
- var o = {};
- o[name] = {"value": fun, "configurable": over};
- MWF.defineProperties(this, o);
- }.bind(this);
- /**
- * 执行代码片段,类似eval。使用Function包装。
- * @module exec()
- * @o2category server.common
- * @o2ordernumber 151
- * @o2cn 方法定义
- * @param text {String} 需要执行的代码片段
- * @param bind {Object} 代码片段中this的指向
- * @param arg {Object} 传入参数。如:{x:1, y:'5'},在代码片段中可使用 x 和 y 变量。
- * @param throwError {boolean} 当代码片段运行错误时,是否抛出错误
- * @returns {any} 返回执行的代码片段的返回值
- */
- this.exec = function(text, bind, arg=null, throwError=true){
- const b = bind || globalThis;
- const p = (arg) ? Object.values(arg) : [];
- const k = (arg) ? Object.keys(arg).join(',') : '';
- try {
- return Function('return function('+k+'){' + text + '}')().apply(b, p);
- }catch(e){
- if (throwError) throw e;
- console.error(e);
- return '';
- }
- }
- //如果前端事件有异步调用,想要在异步调用结束后继续运行页面加载,
- //可在调用前执行 var resolve = this.wait();
- //在异步调用结束后 执行 resolve.cb();
- //目前只有表单的queryload事件支持此方法。
- /**
- * this.wait是一个方法,可以用来处理异步调用时的页面加载。<br/>
- * 该方法使用的具体场景:为了加快速度,需要一次性加载全部外部资源(如:数据字典、外部JS、内容管理文档等)后,再进行表单的加载。<br/>
- * this.wait需和this.goon配合使用。<br/>
- * <b>目前只有流程表单的queryload事件支持此方法。</b>
- * @module wait
- * @o2cn 表单等待
- * @o2category web
- * @o2range {Process}
- * @o2syntax
- * var resolve = this.wait(); //让表单停止加载页面
- *
- * if (resolve && resolve.cb){
- * resolve.cb(); //通过 resolve.cb() 方法继续执行表单加载
- * }else{
- * //如果没有发生异步,则resolve.cb方法不存在,
- * //所以在回调中中使用this.goon();使表单继续加载
- * this.goon();
- * }
- * @example
- * <caption>需要在加载数据字典,内容管理文档数据,按照条件获取的脚本后,再进行加载表单。</caption>
- *
- * var resolve = this.wait(); //this.wait()让表单加载等待回调
- * var scriptLoaded = false; //脚本是否加载完成标识,按条件判断的脚本才建议用this.include(),否则使用预加载脚本更快。
- * var documentLoaded = false; //内容管理文档是否加载完成标识
- * var dictLoaded = true; //数据字典是否加载完成标识
- *
- * //检查是否全部资源已加载,如果是继续加载表单
- * var checkLoad = function(){
- * if (scriptLoaded && documentLoaded && dictLoaded){ //各种资源以及加载完成
- * if (resolve && resolve.cb){
- * resolve.cb(); //通过 resolve.cb() 方法继续执行表单加载
- * }else{
- * //如果没有发生异步,则resolve.cb方法不存在,
- * //所以在回调中中使用this.goon();使表单继续加载
- * this.goon();
- * }
- * }
- * }.bind(this);
- *
- * //判断内容管理文档加载
- * if( this.data.documentId ){
- * //异步载入内容管理文档
- * o2.Actions.get("x_cms_assemble_control").getDocument(this.data.documentId, function (json) {
- * this.form.documentJson = json; //将数据存在this.form上,以便其他地方使用
- * documentLoaded = true; //标记内容管理加载完成
- * checkLoad(); //检查全部资源是否完成加载
- * }.bind(this), null, true); //true 为异步加载标志
- * }else{
- * documentLoaded = true; ////标记内容管理加载完成
- * checkLoad(); //检查全部资源是否完成加载
- * }
- *
- * //判断脚本加载
- * if( this.data.scriptName ){ //假设scriptName为判断条件
- * //加载脚本
- * this.include( this.data.scriptName, function(){ //第二个参数为异步加载后的回调
- * scriptLoaded = true; //标记脚本加载完成
- * checkLoad(); //检查全部资源是否完成加载
- * }, true ); //第三个参数表示异步
- * }else{
- * scriptLoaded = true; ////标记脚本加载完成
- * checkLoad(); //检查全部资源是否完成加载
- * }
- *
- * //加载数据字典bulletinDictionary的category数据
- * var dict = new Dict("bulletinDictionary");
- * dict.get("category", function(data){ //成功的回调
- * this.form.bulletinCategory = data; //将数据存在this.form上,以便其他地方使用
- * dictLoaded = true; //标记数据字典加载完成
- * checkLoad(); //检查全部资源是否完成加载
- * }.bind(this), function(xhr){ //错误的回调
- * dictLoaded = true; ////标记数据字典加载完成
- * checkLoad(); //检查全部资源是否完成加载
- * }, true //异步执行
- * )
- */
- this.wait = function(){
- var _self = this;
- resolve = {"cb": _self.goon.bind(_self)};
- var setResolve = function(callback){
- resolve.cb = callback;
- }.bind(this);
- this.target.event_resolve = setResolve;
- return resolve;
- }
- //和this.wait配合使用,
- //如果没有异步,则resolve.cb方法不存在,
- //所以在回调中中使用this.goon();使表单继续加载
- this.goon = function(){
- this.target.event_resolve = null;
- }
- //仅前台对象-----------------------------------------
- //form
- /**
- * form对象可在流程表单或内容管理表单中可用。(仅前端脚本可用)。
- * @module form
- * @o2cn 流程及内容管理表单
- * @o2category web
- * @o2range {Process|CMS}
- * @o2ordernumber 40
- * @o2syntax
- * //您可以在流程表单和内容管理的前端脚本中,通过this来获取form对象,如下:
- * var form = this.form;
- */
- this.page = this.form = {
- /**
- * 获取当前表单的基本信息。
- * @method getInfor
- * @static
- * @return {Object} 表单的基本信息.
- * <pre><code class='language-js'>{
- * "id": "db3b2766-93a1-4058-b522-0edb922bd84f", //表单ID
- * "name": "报销申请表单", //表单名称
- * "alias": "报销申请表单", //表单别名
- * "description": "", //表单描述
- * "application": "1dc23336-6be6-402b-bed6-36e707a1dd17", //应用ID
- * "lastUpdatePerson": "XX@huqi@P", //最后修改人
- * "lastUpdateTime": "2018-09-30 22:46:30", //最后修改时间
- * "icon": "...", //表单图标
- * }</code></pre>
- * @o2syntax
- * var form = this.form.getInfor();
- */
- "getInfor": function(){return ev.formInfor;},
- "infor": ev.formInfor,
- /**
- * 获取打开当前文档的component对象。平台中每一个窗口应用,就是一个component对象。此处获取到的对象为x_component_process_Work。
- * @method getApp
- * @static
- * @return {x_component_process_Work}打开当前文档的component对象.
- * @o2syntax
- * var app = this.form.getApp();
- * @example
- * var app = this.form.getApp();
- //所有component对象都有以下方法。
- app.openInNewWindow(); //在新窗口中打开当前应用
- app.setCurrent(); //将当前应用设置为激活状态
- app.minSize(); //应用窗口最小化
- app.maxSize(); //应用窗口最大化
- app.restoreSize(); //应用窗口还原
- app.refresh(); //刷新应用
- app.close(); //关闭应用
- app.setTitle(str); //设置应用标题
- app.dialog(option); //弹出一个对话框(详见MWF.widget.Dialog)
- //显示一个通知消息
- app.notice(content, type, target, where, offset);
- //显示一个确认框
- app.confirm(type, e, title, text, width, height, ok, cancel);
- //弹出一个信息框
- app.alert(type, e, title, text, width, height);
- //为应用绑定一个事件
- app.addEvent(type, fun);
- */
- "getApp": function(){return _form.app;},
- "app": _form.app,
- /**
- * 获取Form对应的DOM对象。
- * @method node
- * @static
- * @return {HTMLDivElement} 当前form对应的div对象.
- * @o2syntax
- * var node = this.form.node();
- */
- "node": function(){return _form.node;},
- // "readonly": _form.options.readonly,
- /**
- * 获取表单元素对象。<br/>
- * <table>
- * <tr><td>Actionbar(操作条)</td><td>Address(地址输入框)</td><td>Attachment(附件框)</td><td>Button(按钮)</td></tr>
- * <tr><td>Calendar(日期输入框)</td><td>Checkbox(多选按钮)</td><td>Combox(组合框)</td><td>Datagrid(数据网格)</td></tr>
- * <tr><td>Div(容器)</td><td>Htmleditor(富文本编辑框)</td><td>Html(内置html)</td><td>Iframe(嵌入Iframe)</td></tr>
- * <tr><td>Image(图片)</td><td>Label(文本)</td><td>Log(流程意见)</td><td>Monitor(流程监控)</td></tr>
- * <tr><td>Number(数字输入框)</td><td>Office(office控件)</td><td>Opinion(意见框)</td><td>Org(人员组织选择)</td></tr>
- * <tr><td>Radio(单选按钮)</td><td>Select(选择框)</td><td>Sidebar(侧边操作条)</td><td>Stat(统计组件)</td></tr>
- * <tr><td>Subform(子表单)</td><td>Tab(分页)</td><td>Table(表格)</td><td>Textarea(多行输入)</td></tr>
- * <tr><td>Textfield(文本输入框)</td><td>Tree(树状控件)</td><td>View(视图组件)</td><td>ViewSelector(视图选择组件)</td></tr>
- * <tr><td>Documenteditor(公文编辑器)</td><td>ImageClipper(图片编辑器)</td><td></td><td></td></tr>
- * </table>
- * @method get
- * @static
- * @return {FormComponent} 请查看本文档的Classes导航下的FormComponents。
- * @param {String} name 字段标识
- * @param {String} [subformName] 子表单/部件标识。当开发人员在插入子表单的时候,系统会检查输入类型(会在后台存值)的组件是否重名,如果重名则不允许插入。
- * 但是布局组件(如div)重名会被允许。系统在展现表单的时候会判断子表单中组件的标识是否被使用,如果是会自动在组件前加上"子表单标识_",如:主表单有一个"div_1",则子表单"subform1"的"div_1"组件标识则变为"subform1_div_1"。
- * 本参数就是用在这种情况下,可以正确返回子表单中的组件。
- * @o2syntax
- * var field = this.form.get(name);
- * @o2syntax
- * var field = this.form.get(name, subformName);
- * @example
- * var field = this.form.get("subject");
- * @example
- * var field = this.form.get("div", "subform1"); //获取子表单“subform1”中的div,如果子表单无此组件,而主表单有,则返回主表单的组件。
- */
- "get": function(name,subformName ){
- if( !_form.all )return null;
- if( subformName ){
- if( _form.all[subformName +"_"+ name] )return _form.all[subformName +"_"+ name];
- return _form.all[name];
- }else{
- return _form.all[name];
- }
- // return (_form.all) ? _form.all[name] : null;
- },
- /**
- * 获取表单中可输入的字段元素对象。<br/>
- * <table>
- * <tr><td>Address(地址输入框)</td><td>Attachment(附件框)</td><td>Calendar(日期输入框)</td><td>Checkbox(多选按钮)</td></tr>
- * <tr><td>Combox(组合框)</td><td>Datagrid(数据网格)</td><td>Htmleditor(富文本编辑框)</td><td>Number(数字输入框)</td></tr>
- * <tr><td>Org(人员组织选择)</td><td>Radio(单选按钮)</td><td>Select(选择框)</td><td>Textarea(多行输入)</td></tr>
- * <tr><td>Textfield(文本输入框)</td><td></td><td></td><td></td></tr>
- * </table>
- * @method getField
- * @static
- * @return {FormComponent} 请查看本文档的Classes导航下的FormComponents。
- * @param {String} name 字段标识
- * @o2syntax
- * var field = this.form.getField(name);
- * @example
- * var field = this.form.getField("subject");
- */
- "getField": function(name){return _forms[name];},
- "getAction": function(){return _form.workAction},
- "getDesktop": function(){return _form.app.desktop},
- /**获取业务数据
- * @method getData
- * @static
- * @see module:data
- * @o2syntax
- * var data = this.form.getData();
- * @return {Object} 返回表单绑定的业务数据。
- */
- "getData": function(){return new MWF.xScript.JSONData(_form.getData());},
- /**保存当前表单所绑定的业务数据。<br/>
- * this.form.save()会触发 beforeSave和afterSave事件,因此在beforeSave和afterSave中不允许使用本方法。同时不建议在queryLoad里使用本方法。
- * @method save
- * @static
- * @param {Function} [callback] - 保存后的回调
- * @param {Boolean} [silent] - 是否静默,否提示保存成功,默认为false
- * @o2syntax
- * this.form.save(callback, silent);
- * @example
- * this.form.save(function(){
- * //do someting
- * }, true);
- */
- "save": function(callback, silent){_form.saveWork(callback, silent); },
- /**
- *关闭当前表单
- * @method close
- * @static
- * @example
- * this.form.close();
- */
- "close": function(){_form.closeWork();},
- /**
- *挂起当前待办
- * @method pauseTask
- * @static
- * @example
- * this.form.pauseTask();
- */
- "pauseTask": function(){_form.pauseTask();},
- /**
- *将待办从挂起状态恢复为正常状态
- * @method resumeTask
- * @static
- * @example
- * this.form.resumeTask();
- */
- "resumeTask": function(){_form.resumeTask();},
- /**本校验不包括校验意见,校验路由;通常用在弹出提交界面时候的校验
- * @summary 根据表单中所有组件的校验设置和“流转校验”脚本进行校验。<b>(仅流程表单中可用)</b>
- * @method verify
- * @static
- * @o2syntax
- * this.form.verify()
- * @example
- * if( !this.form.verify() ){
- * return false;
- * }
- * @return {Boolean} 是否通过校验
- */
- "verify": function(){
- return !(!_form.formCustomValidation("", "") || !_form.formValidation("", ""));
- },
- /**
- * @summary 根据表单中所有组件的校验设置和表单的“发布校验”脚本进行校验。<b>(仅内容管理表单中可用)</b>
- * @method verifyPublish
- * @static
- * @o2syntax
- * this.form.verifyPublish()
- * @example
- * if( !this.form.verifyPublish() ){
- * return false;
- * }
- * @return {Boolean} 是否通过校验
- */
- "verifyPublish": function(isSave){
- return !(!_form.formValidation(isSave ? "" : "publish") || !_form[isSave ? 'formSaveValidation' : 'formPublishValidation']());
- },
- /**对当前表单打开的流程实例进行流转。<b>(仅流程表单中可用)</b><br/>
- * 可以通过this.workContext.getControl().allowProcessing来判断当前用户是否有权限进行流转。<br/>
- * this.form.process()会触发 beforeSave、afterSave、beforeProcess、afterProcess事件,因此在上述事件中不允许使用本方法。
- * @method process
- * @static
- * @param {Object} [option] - 流程的相关数据,如果不带此参数,则弹出路由选择和意见填写框<br/>
- * 格式如下:
- <pre><code class="language-js">
- {
- "routeName": "", //流转到下一步要选择的路由名称
- "opinion": "", //流转意见
- "callback": function(json){} //回调方法,有json参数表示正常流转,json参数为流转后返回的数据。
- }
- </code></pre>
- * @example
- //不带参数,弹出路由选择和意见填写框
- this.form.process();
- * @example
- //带参数,流转
- this.form.process({
- "routeName": "送审批",
- "opinion": "同意",
- "callback": function(json){
- if(json)this.form.notice("process success", "success");
- }.bind(this)
- });
- */
- "process": function(option){
- var op = _form.getOpinion();
- var mds = op.medias;
- if (option){
- _form.submitWork(option.routeName, option.opinion, mds, option.callback,
- option.processor, null, option.appendTaskIdentityList, option.processorOrgList, option.callbackBeforeSave );
- }else{
- _form.processWork();
- }
- },
- /**对当前文档的待办重新设定处理人。<b>(仅流程表单中可用)</b><br/>
- * 可以通过this.workContext.getControl().allowReset来判断当前用户是否有权限重置处理人。<br/>
- * @method reset
- * @static
- * @param {Object} [option] - 进行重置处理人的相关参数,如果不带此参数,弹出重置处理人对话框<br/>
- * 格式如下:
- <pre><code class="language-js">
- {
- "names": "", //{Array|String} 要重置给哪些身份
- "opinion": "", //流转意见
- "success": function(){}, //重置成功后的回调方法
- "failure": function(){} //重置失败后的回调方法
- }
- </code></pre>
- * @example
- //不带参数,弹出重置处理人对话框,用户确定后会触发 beforeReset、afterReset事件,因此在这两个事件中不允许使用本方法。
- this.form.reset();
- * @example
- //带参数,直接调用后台服务重置,不会触发 beforeReset、afterReset事件
- this.form.reset({
- "names": ["张三@zhangsan@I"],
- "opinion": "授权处理",
- "success": function(json){
- this.form.notice("reset success", "success");
- }.bind(this),
- "failure": function(xhr, text, error){
- //xhr--HttpRequest请求对象
- //text--HttpResponse内容文本
- //error--错误信息
- this.form.notice("reset failure:"+error, "error");
- }.bind(this)
- });
- */
- "reset": function(option){
- if (!option){
- if (_form.businessData.control["allowReset"]) _form.resetWork();
- }else{
- _form.resetWorkToPeson(option.names, option.opinion, option.routeName || "", option.success, option.failure);
- }
- },
- /**撤回文档操作,上一个处理人收回已经流转下去的文件。<b>(仅流程表单中可用)</b><br/>
- * 这个操作只允许上一个处理人在流转文件之后,下一个处理人未处理的时候执行。<br/>
- * 可以通过this.workContext.getControl().allowRetract来判断当前用户是否有权限撤回。<br/>
- * @method retract
- * @static
- * @param {Object} [option] - 进行撤回的相关参数,如果不提供option参数,则弹出撤回对话框。<br/>
- * 格式如下:
- <pre><code class="language-js">
- {
- "success": function(){}, //撤回成功后的回调方法
- "failure": function(){} //撤回失败后的回调方法
- }
- </code></pre>
- * @example
- //不带参数,则弹出撤回对话框,用户确定后会触发 beforeRetract、afterRetract事件,因此在这两个事件中不允许使用本方法。
- this.form.retract();
- * @example
- //带参数,直接调用后台服务撤回,不会出发beforeRetract、afterRetract事件
- this.form.retract({
- "success": function(json){
- this.form.notice("retract success", "success");
- }.bind(this),
- "failure": function(xhr, text, error){
- //xhr--HttpRequest请求对象
- //text--HttpResponse内容文本
- //error--错误信息
- this.form.notice("retract failure: "+error, "error");
- }.bind(this)
- });
- */
- "retract": function(option){
- if (!option){
- if (_form.businessData.control["allowRetract"]) _form.retractWork();
- }else{
- _form.doRetractWork(option.success, option.failure);
- }
- },
- /**在已拆分的工作上添加分支。<b>(仅流程表单中可用)</b><br/>
- * 可以通过this.workContext.getControl().allowAddSplit来判断当前用户是否有权限。<br/>
- * @method addSplit
- * @static
- * @param {Object} [option] - 添加分支的相关参数,如果不提供option参数,则弹出添加分支对话框。<br/>
- * 格式如下:
- <pre><code class="language-js">
- {
- "value" : [], //splitValueList 添加的拆分值,拆分值取决于流程拆分节点的设置
- "trimExist" : true, //排除已经存在的拆分值.
- "success": function(){}, //执行成功后的回调方法
- "failure": function(){} //执行失败后的回调方法
- }
- </code></pre>
- * @example
- //不带参数,则弹出添加分支对话框,用户确定后会触发beforeAddSplit、afterAddSplit事件
- this.form.addSplit();
- * @example
- //带参数,直接调用后天服务添加分支,不会触发beforeAddSplit、afterAddSplit事件
- this.form.addSplit({
- "value" : ["开发部@kfb@U"],
- "trimExist" : true,
- "success": function(json){
- this.form.notice("addSplit success", "success");
- }.bind(this),
- "failure": function(xhr, text, error){
- //xhr--HttpRequest请求对象
- //text--HttpResponse内容文本
- //error--错误信息
- this.form.notice("addSplit failure: "+error, "error");
- }.bind(this)
- });
- */
- "addSplit": function(option){
- if (!option){
- if (_form.businessData.control["allowAddSplit"]) _form.addSplit();
- }else{
- _form.addSplitWork(option.value, option.trimExist, option.success, option.failure);
- }
- },
- "rollback": function(option){
- if (!option){
- if (_form.businessData.control["allowRollback"]) _form.rollback();
- }else{
- _form.doRollbackActionInvoke(option.log, option.flow, option.success, option.failure);
- }
- },
- /**删除当前工作文档。<b>(仅流程表单中可用)</b><br/>
- * 可以通过this.workContext.getControl().allowDeleteWork来判断当前用户是否有权限删除文档。<br/>
- * @method deleteWork
- * @static
- * @param {Object} [option] - 删除相关参数,如果不提供option参数,则弹出删除对话框。<br/>
- * 格式如下:
- <pre><code class="language-js">
- {
- "success": function(){}, //执行成功后的回调方法
- "failure": function(){} //执行失败后的回调方法
- }
- </code></pre>
- * @example
- //不带参数,则弹出删除提示对话框,用户确定后触发beforeDelete和afterDelete事件
- this.form.deleteWork();
- * @example
- //带参数,直接调用服务删除,不触发beforeDelete和afterDelete事件
- this.form.deleteWork({
- "success": function(json){
- this.form.notice("deleteWork success", "success");
- }.bind(this),
- "failure": function(xhr, text, error){
- //xhr--HttpRequest请求对象
- //text--HttpResponse内容文本
- //error--错误信息
- this.form.notice("deleteWork failure: "+error, "error");
- }.bind(this)
- });
- */
- "deleteWork": function(option){
- if (!option){
- if (_form.businessData.control["allowDelete"]) _form.deleteWork();
- }else{
- _form.doDeleteWork(option.success, option.failure);
- }
- },
- /**对当前工作发送待阅。<b>(仅流程表单中可用)</b><br/>
- * 能查看工作的人都有权限发送。<br/>
- * this.form.sendRead()会触发 beforeSendRead、afterSendRead,因此在上述事件中不允许使用本方法。
- * @method sendRead
- * @static
- * @param {Object} [option] - 发送待阅的相关参数,如果不带此参数,弹出发送待阅对话框<br/>
- * 格式如下:
- <pre><code class="language-js">
- {
- "identityList": "", //{Array|String} 要给哪些身份发送待阅
- "notify": true, //是否发送待阅通知(需要服务器开启消息)
- "success": function(){}, //成功后的回调方法
- "failure": function(){} //失败后的回调方法
- }
- </code></pre>
- * @example
- //不带参数,弹出发送待阅对话框,确定后触发beforeSendRead,afterSendRead事件
- this.form.sendRead();
- * @example
- //带参数,直接调用后台服务发送待阅,触发beforeSendRead,afterSendRead事件
- this.form.sendRead({
- "identityList": ["张三@zhangsan@I"],
- "notify": false,
- "success": function(json){
- this.form.notice("send read success", "success");
- }.bind(this),
- "failure": function(xhr, text, error){
- //xhr--HttpRequest请求对象
- //text--HttpResponse内容文本
- //error--错误信息
- this.form.notice("send read failure:"+error, "error");
- }.bind(this)
- });
- */
- "sendRead": function(option){
- if (!option){
- _form.sendRead();
- }else{
- if( option.identityList && typeOf(option.identityList) === "string" ){
- option.identityList = [option.identityList];
- }
- _form.doSendRead(option);
- }
- },
- /**对当前工作添加阅读人(参阅)。<b>(仅流程表单中可用)</b><br/>
- * 能查看工作的人都有权限添加。<br/>
- * this.form.addReview()会触发 beforeAddReview、afterAddReview,因此在上述事件中不允许使用本方法。
- * @method addReview
- * @static
- * @param {Object} [option] - 添加阅读人的相关参数,如果不带此参数,弹出添加阅读人对话框<br/>
- * 格式如下:
- <pre><code class="language-js">
- {
- "personList": "", //{Array|String} 要添加哪些阅读人
- "success": function(){}, //成功后的回调方法
- "failure": function(){} //失败后的回调方法
- }
- </code></pre>
- * @example
- //不带参数,弹出添加阅读人对话框,触发beforeAddReview和afterAddReview事件。
- this.form.addReview();
- * @example
- //带参数,直接调用后台服务发送待阅,触发beforeAddReview和afterAddReview事件。
- this.form.addReview({
- "personList": ["张三@zhangsan@P"],
- "success": function(json){
- this.form.notice("add review success", "success");
- }.bind(this),
- "failure": function(xhr, text, error){
- //xhr--HttpRequest请求对象
- //text--HttpResponse内容文本
- //error--错误信息
- this.form.notice("add review failure:"+error, "error");
- }.bind(this)
- });
- */
- "addReview": function(option){
- if (!option){
- _form.addReview();
- }else{
- if( option.personList && typeOf(option.personList) === "string" ){
- option.personList = [option.personList];
- }
- _form.doAddReview(option);
- }
- },
- /**创建关联当前工作的聊天群。<b>(仅流程表单中可用)</b><br/>
- * 根据当前工作的关联人员创建聊天群。<br/>
- * @method startIM
- * @static
- * @param {String} [jobId] - 当前工作的jobId<br/>
- *
- * @example
- //带参数,启动创建界面
- this.form.startIM("jobId");
- */
- "startIM": function(jobId){
- _form.openIMChatStarter(jobId);
- },
- /**分享当前工作到IM聊天会话中。<b>(仅流程表单中可用)</b><br/>
- * @method shareToIMChat
- * @static
- *
- * @example
- //不带参数
- this.form.shareToIMChat();
- */
- "shareToIMChat": function(){
- _form.shareToIMChat();
- },
- /**添加待办人,可用于加签等操作。<b>(仅流程表单中可用)</b><br/>
- * 可以通过this.workContext.getControl().allowAddTask来判断当前用户是否有权限。<br/>
- * @method addTask
- * @static
- * @param {Object} [option] - 添加待办人的相关参数,如果不提供option参数,则弹出加签对话框。<br/>
- * 格式如下:
- * <pre><code class="language-js">
- * {
- * "mode" : "single", //加签模式:single,queue,parallel
- * "before" : true, //是否是前加签,false后加签.
- * "distinguishedNameList": [], //加签人的身份数组。
- * "routeName" : "", //增加待办在流程记录中显示的路由.
- * "opinion" : "", //加签意见
- * "success": function(){}, //执行成功后的回调方法
- * "failure": function(){} //执行失败后的回调方法
- * }
- </code></pre>
- * @example
- * //不带参数,则弹出加签对话框
- * this.form.addTask();
- * @example
- * //带参数,根据参数执行添加待办操作
- * this.form.addTask({
- * "mode" : "single",
- * "before": false,
- * "distinguishedNameList": ["张三@XXXX@I", "李四@XXXX@I"],
- * "routeName" : "添加审阅人",
- * "opinion" : "请张三、李四审阅",
- * "success": function(json){
- * this.form.notice("addTask success", "success");
- * }.bind(this),
- * "failure": function(xhr, text, error){
- * //xhr--HttpRequest请求对象
- * //text--HttpResponse内容文本
- * //error--错误信息
- * this.form.notice("addTask failure: "+error, "error");
- * }.bind(this)
- * });
- */
- "addTask": function(option){
- if (option){
- (function(callback){
- if (_form.businessData.control["allowSave"]){
- _form.saveFormData(callback);
- }else{
- if (callback) callback();
- }
- })(function(){
- // if (!option.identity){
- // option.identity = (_form.businessData.task) && _form.businessData.task.identityDn;
- // }
- // var workId = _form.businessData.work.id;
- // o2.Actions.load("x_processplatform_assemble_surface").WorkAction.V2AddManualTaskIdentityMatrix(workId, option, option.success, option.failure);
- // var taskId = _form.businessData.task.id;
- // o2.Actions.load("x_processplatform_assemble_surface").TaskAction.v3Add(taskId, option, option.success, option.failure);
- _form.doAddTaskToPeople(option.distinguishedNameList, option.opinion, option.mode, option.before, option.routeName || "", option.success, option.failure)
- });
- }else{
- if (_form.businessData.control["allowAddTask"]) _form.addTask();
- }
- },
- /**弹出一个确认框,带确认和关闭按钮
- * @method confirm
- * @static
- * @param {String} type - 要显示的信息类型。可选值:success 成功,info :信息,error :错误, wran : 警告
- * @param {String} title - 确认框标题栏显示文本。
- * @param {String|Object} text - 确认框的内容显示文本。值为html的时候见下面的样例“使用html传入内容”。
- * @param {Number} width - 确认框的宽度。
- * @param {String} height - 确认框的高度。
- * @param {Function} ok - 点击“确定”按钮后的回调函数。
- * @param {Function} cancel - 点击“取消”按钮后的回调函数。
- * @example
- *this.form.confirm("wran", "删除确认", "您确定要删除吗?", 300, 100,function(){
- * //执行删除代码
- * this.close();
- *}, function(){
- * this.close();
- *});
- * @example
- * //使用html传入内容, v8.1开始支持
- *this.form.confirm("wran", "删除确认", {
- * html: "您确定要删除吗!<br/>"
- *}, 300, 100,function(){
- * //执行删除代码
- * this.close();
- *}, function(){
- * this.close();
- *});
- */
- "confirm": function(type, title, text, width, height, ok, cancel, callback, mask, style){
- if ((arguments.length<=1) || o2.typeOf(arguments[1])==="string"){
- var p = MWF.getCenter({"x": width, "y": height});
- e = {"event": {"clientX": p.x,"x": p.x,"clientY": p.y,"y": p.y}};
- _form.confirm(type, e, title, text, width, height, ok, cancel, callback, mask, style);
- }else{
- e = (arguments.length>1) ? arguments[1] : null;
- title = (arguments.length>2) ? arguments[2] : null;
- text = (arguments.length>3) ? arguments[3] : null;
- width = (arguments.length>4) ? arguments[4] : null;
- height = (arguments.length>5) ? arguments[5] : null;
- ok = (arguments.length>6) ? arguments[6] : null;
- cancel = (arguments.length>7) ? arguments[7] : null;
- callback = (arguments.length>8) ? arguments[8] : null;
- mask = (arguments.length>9) ? arguments[9] : null;
- style = (arguments.length>10) ? arguments[10] : null;
- // var p = MWF.getCenter({"x": width, "y": height});
- // e = {"event": {"clientX": p.x,"x": p.x,"clientY": p.y,"y": p.y}};
- _form.confirm(type, e, title, text, width, height, ok, cancel, callback, mask, style);
- }
- },
- /**弹出一个带关闭按钮的信息框
- * @method alert
- * @static
- * @param {String} type - 要显示的信息类型。可选值:success 成功,info :信息,error :错误, wran : 警告
- * @param {String} title - 信息框标题栏显示文本。
- * @param {String|Object} text - 信息框的内容显示文本。值为html的时候见下面的样例“使用html传入内容”。
- * @param {Number} width - 信息框宽度。
- * @param {String} height - 信息框的高度。
- * @example
- * this.form.alert("wran", "必填提醒", "请填写标题!", 300, 100);
- * @example
- * //使用html传入内容
- * this.form.alert("wran", "必填提醒", {
- * html: "请填写标题!<br/>"
- * }, 300, 100);
- */
- "alert": function(type, title, text, width, height){
- _form.alert(type, title, text, width, height);
- },
- /**弹出一个提示框
- * @method notice
- * @static
- * @param {String} content - 要显示的信息文本
- * @param {String} [type] - 要显示的信息类型。可选值:success 成功,info :信息,error :错误, warn : 警告
- * @param {Element} [target] - 信息框显示位置的参考DOM对象。
- * @param {Object} [where] - 信息框显示相对于target的x轴和y轴位置。<br/>
- * 如: {"x": "center", "y": "center"}<br/>
- x : <br/>
- 水平位置,可用“left”、“right”和“center”;可以用数组定义外部(outside)位置和内部(inside)位置,如:['right', 'inside']<br/>
- y :<br/>
- 垂直位置,可用“top”、“bottom”和“center”;可以用数组定义外部(outside)位置和内部(inside)位置,如:['top', 'outside']。
- * @param {Object} [offset] - 相对位置的偏移量,允许负值。如:{"x": 10, "y": -10}
- * @param {Object} [option] - 其他选项。如: { delayClose: 5000 } 在5秒后关闭
- * @example
- this.form.notice("this is my information", "info");
- */
- "notice": function(content, type, target, where, offset, option){
- _form.notice(content, type, target, where, offset, option);
- },
- /**弹出一个对话框层。
- * @method dialog
- * @static
- * @return {Object} 对话框对象。
- * @param {(Object)} options
- * 弹出框选项:<br/>
- * 如果有buttonList参数,则ok,cancel参数无效。<br/>
- * 对话框内容的优先级为moduleName、content、url、html、text,有前面的参数则后面的参数无效。<br/>
- * 调用弹出框对象后各事件执行先后顺序 onQueryLoad-->onPostLoad-->onQueryShow-->onPostShow。<br/>
- * 其他说明如下:
- * <pre><code class="language-js">{
- * "style" : "default", //(string)可选,弹出框使用的样式,默认是user,系统内置一些样式,比如:user,blue_flat,o2,flat等,对应样式文件位置:webserver\o2_core\o2\widget\$Dialog,用户也可以自己增加自定义样式风格,对应文件及结构参考已有样式风格。
- * "title" : "", //(string)可选,弹出框头部标题,在isTitle参数为true时有效。
- * "width" : 300, //(number)可选,弹出框宽度。 默认值:300
- * "height" : 150, //(number)可选,弹出框高度。 默认值:150
- * "isTitle" : true, //(boolean)可选,弹出框是否有标题栏。默认值:true。
- * "isMax" : false, //(boolean)可选,标题栏是否有最大化按钮,相对应有还原按钮,默认值:false。
- * "isClose" : false, //(boolean)可选,标题栏是否有关闭按钮。默认值:false。
- * "isResize" : true, //(boolean)可选,弹出框大小是否可调整。默认值:true。
- * "isMove" : true, //(boolean)可选,弹出框是否可移动。默认值:true。
- * "offset" : {"x":-200, "y": -100}, //(object)可选,弹出框相对容器(container)的x轴y轴位置偏移量,空则居中。
- * "mask" : true, //(boolean)可选,是否需要遮罩层。默认值:true。
- * "duration" : true, //(number)可选,动画显示弹出框效果时间。默认值:200。
- * "zindex": 100, //(number)可选,弹出框的z轴优先级,默认为100(日期控件的zindex为300,选人控件为1000,最好不要高于300)。
- * "buttonList" : [
- * {
- * "type": "ok", //(string) 样式,彩色底的按钮
- * "text": "确定", //(string)text:按钮显示名称
- * "action": function(){ //(function) 按钮对应的点击事件
- * //do something,this指向本对话框对象
- * this.close();
- * }
- * },
- * {
- * "type": "cancel", //(string) 样式,灰色底的按钮
- * "text": "取消",
- * "action": function(){
- * //do something
- * this.close();
- * }
- * }
- * ], //(Array)可选,定义底部按钮,数组列表。无该参数则默认有确定和取消两个按钮,这个时候options可以传入ok或者cancel方法作为回调。如果传入空数组“[]”则底部无按钮。
- * "ok": function(){}, //(function) 可选,无options.buttonList参数的时候,该方法作为“确定”按钮的回调方法,返回true关闭对话框,options.buttonList不为空则忽略该方法。
- * "close": function(){}, //(function) 可选,无options.buttonList参数的时候,该方法作为“取消”按钮的回调方法,返回true关闭对话框,options.buttonList不为空则忽略该方法。
- * "container" : this.form.getApp().content, //(Element/Dom)可选,弹出框层dom对象的父dom,位置相对对象。移动端默认插入到body中,PC端默认插入到表单节点所在容器(this.form.getApp().content)。
- * "moduleName": "div_1", //内容参数,优先级为1,(String)可选,表示表单组件名称,系统会获取该组件的node节点作为对话框内容,关闭对话框节点会插回到原来的位置。
- * "content": this.form.get("div1").node, //内容参数,优先级为2,(Element/Dom)可选,对话框内容,如果节点在document中,关闭对话框节点会插回到原来的位置。
- * "url": "http://xxx/xxx.html", //内容参数,优先级为3,(String)可选,该参数所指向的内容作为对话框的内容。
- * "html": "<div>html内容</div>", //内容参数,优先级为4,(String)可选,对话框的html内容。
- * "text": "文本内容", //内容参数,优先级为5,(String)可选,对话框的文本内容。
- * "onQueryClose": function(){}, //(function) 可选,关闭弹出框前事件,this指向对话框对象。
- * "onPostClose": function(){}, //(function) 可选,关闭弹出框后事件,this指向对话框对象。
- * "onQueryLoad": function(){}, //(function) 可选,弹出框载入前事件,this指向对话框对象。
- * "onPostLoad": function(){}, //(function) 可选,弹出框载入后事件,this指向对话框对象。
- * "onQueryShow": function(){}, //(function) 可选,弹出框显示前事件,this指向对话框对象。
- * "onPostShow": function(){} //(function) 可选,弹出框显示后事件,this指向对话框对象。
- * }</code></pre>
- * @example
- * //打开一个对话框,使用html作为内容
- * var _self = this;
- * var dlg = this.form.dialog({
- * "title": "填写内容",
- * "width": "500",
- * "height": "300",
- * "html": "<div>内容:</div><div><input type='text'></div>",
- * "ok": function(){
- * var value = this.node.getElement("input").value; //this指向对话框对象
- * if( !value ){
- * _self.form.notice("请填写内容", "info");
- * return false; //返回false不关闭对话框
- * }else{
- * return true; //返回true关闭对话框
- * }
- * }
- *});
- * @example
- * //打开一个对话框,使用表单中的div_1组件作为内容
- * var _self = this;
- * this.form.dialog({
- * "title": "填写内容",
- * "width": "400",
- * "height": "200",
- * "moduleName": "div_1", //内容为表单上的组件,标识为div_1
- * "buttonList" : [
- * {
- * "type": "ok", //(string) 样式,彩色底的按钮
- * "text": "确定", //(string)text:按钮显示名称
- * "action": function(){ //(function) 按钮对应的点击事件
- * //do something,this指向本对话框对象
- * var value = _self.form.get("textfield").getData(); //获取div_1中的组件textfield的值
- * if( !value ){
- * _self.form.notice("请填写内容","info");
- * }else{
- * this.close();
- * }
- * }
- * },
- * {
- * "type": "cancel", //(string) 样式,灰色底的按钮
- * "text": "取消",
- * "action": function(){
- * //do something
- * this.close();
- * }
- * }
- * ]
- * });
- * @example
- * //打开一个对话框,创建Dom节点作为内容
- * var _self = this;
- * var content = new Element("div");
- * new Element("label", {
- * text: "内容:"
- * }).inject(content);
- * new Element("input", {
- * type: "text"
- * }).inject(content);
- * this.form.dialog({
- * "title": "填写内容",
- * "width": "400",
- * "height": "200",
- * "zindex": 301, //z轴优先级为301
- * "content": content, //new Element创建的内容,也可以使用 this.form.get(xx).node 作为内容
- * "buttonList" : [
- * {
- * "type": "ok", //(string) 样式,彩色底的按钮
- * "text": "确定", //(string)text:按钮显示名称
- * "action": function(){ //(function) 按钮对应的点击事件
- * //do something,this指向本对话框对象
- * var value = this.node.getElement("input").get("value"); //获取对话框节点中的input的值
- * if( !value ){
- * _self.form.notice("请填写内容","info");
- * }else{
- * this.close();
- * }
- * }
- * },
- * {
- * "type": "cancel", //(string) 样式,灰色底的按钮
- * "text": "取消",
- * "action": function(){
- * //do something
- * this.close();
- * }
- * }
- * ],
- * "onQueryClose": function(){
- * console.log("-onQueryClose-");
- * },
- * "onPostClose": function(){
- * console.log("-onPostClose-");
- * },
- * "onQueryLoad":function(){
- * console.log("-onQueryLoad-");
- * },
- * "onPostLoad": function(){
- * console.log("-onPostLoad-");
- * },
- * "onQueryShow": function(){
- * console.log("-onQueryshow-");
- * },
- * "onPostShow": function(){
- * console.log("-onPostShow-");
- * }.bind(this)
- * });
- */
- "dialog": function ( options ) {
- return _form.dialog( options );
- },
- /**弹出人员组织选择界面,支持身份、个人、组织、群组的单个选择或复合选择。该方法参数适用于 new MWF.O2Selector()。
- * @method selectOrg
- * @static
- * @return {Object} 人员组织选择器对象。
- * @param {Element} container - 人员选择界面的所在容器,默认为当前应用的容器。
- * @param {Object} options - 人员组织选择选项。<br/>
- * <pre><code class="language-js">{
- * "type": "", //选择类型,和types二选一,可选值为 identity(身份), person(个人), unit(组织), group(群组),
- * "types": [], //复合选择,和type二选一,如 ["identity", "person", "unit", "group"]
- * "count": 0, //选择数量,0表示不限制
- * "title": "", //选择界面的title
- * "values": [], //已选择的值
- *
- * "groups": [], //选择的群组范围,选择群组时有效。
- *
- * "units": [], //选择的组织范围,选择身份和组织时有效
- * "resultType" : "", //可以设置成"person"(个人),那么结果返回个人。选择身份时有效。用在选择人员,但是需要按照组织层级展现的场景。
- * "dutys": [], //选择的职务范围,选择身份时有效。
- * "categoryType": "", //可使用unit或duty。如果指定了选择的职务范围(dutys不为空),按unit(组织)还是按duty(职务)来展现分类,默认为按unit。该参数在选择身份时有效。
- *
- * "noUnit" : false, //在选择身份的时候,是否只使用include选项。
- * "include" : [], //增加的可选项。选择身份的时候,没有传units表示选中全员,include不生效,可以使用onUnit选项表示只使用include选项。
- * "exclude" : [], //排除的可选项
- *
- * "expandSubEnable" : true, //是否允许展开下一层,选择身份和组织时有效
- * "selectAllEnable" : true, //分类是否允许全选下一层,选择身份和组织时有效
- *
- * "level1Indent" : 10, //第一级的缩进
- * "indent" : 10, //后续的缩进
- * "zIndex": 1000, //选择界面的zIndex,
- *
- * "onComplete" : function( selectedItemList ){
- * //点击确定时执行
- * //selectedItemList为选中的item对象,下面的selectedDataList为选中的数据
- * var selectedDataList = selectedItemList.map( function(item){
- * return item.data;
- * })
- * },
- * "onCancel" : function(selector) {
- * //点击取消时的事件, selector 为选择器, this为选择器
- * },
- * "onQueryLoad" : function(selector) {
- * //加载选择器前事件, selector 为选择器, this为选择器
- * },
- * "onLoad" : function(selector) {
- * //加载选择器后事件, selector 为选择器, this为选择器
- * },
- * "onCancel" : function(selector) {
- * //点击取消时的事件, selector 为选择器, this为选择器
- * },
- * "onQueryLoadCategory" : function(category) {
- * //加载分类前事件, category 为 分类对象, this为选择器
- * },
- * "onPostLoadCategory" : function(category) {
- * //加载分类后事件, category 为 分类对象, this为选择器
- * },
- * "onSelectCategory" : function(category){
- * //选择分类, category 为 分类对象, this为选择器
- * },
- * "onUnselectCategory": function(category){
- * //取消选择分类, category 为 分类对象, this为选择器
- * },
- * "onQueryLoadItem" : function(item){
- * //加载项目前事件, item 为 项目对象, this为选择器
- * },
- * "onPostLoadItem" : function(item){
- * //加载项目后事件, item 为 项目对象, this为选择器
- * },
- * "onSelectItem" : function(item){
- * //选择项目事件, item 为 项目对象, this为选择器
- * },
- * "onUnselectItem" : function(item){
- * //取消选择项目事件, item 为 项目对象, this为选择器
- * },
- * "onExpand" : function( obj ){
- * //展开分类, obj 为分类/项目, this为选择器
- * },
- * "onCollapse" : function(obj){
- * //折叠分类,obj 为分类/项目, this为选择器
- * }
- *}</code></pre>
- * @example
- * //选择身份
- * var selector = this.form.selectOrg(null, {
- * type: "identity",
- * onComplete : function( selectedItemList ){
- * //点击确定时执行
- * //selectedItemList为选中的item对象,下面的selectedDataList为选中的数据
- * var selectedDataList = selectedItemList.map( function(item){
- * return item.data;
- * })
- * }
- *});
- * @example
- * //在限定组织内选择身份
- * var selector = this.form.selectOrg(null, {
- * type: "identity",
- * units: ["兰德纵横@landzone@U"],
- * onComplete : function( selectedItemList ){
- * }
- *});
- * @example
- * //在限定职务时选择身份
- * var selector = this.form.selectOrg(null, {
- * type: "identity",
- * dutys: ["部门正职"],
- * onComplete : function( selectedItemList ){
- * }
- *});
- * @example
- * //同时选择组织、群组、身份、个人
- * var selector = this.form.selectOrg(null, {
- * types: ["unit", "group", "identity", "person"],
- * onComplete : function( selectedItemList ){
- * }
- *});
- */
- "selectOrg": function ( container, options, delayLoad) {
- if( !container )container = _form.app.content;
- return new MWF.O2Selector(container, options, delayLoad);
- },
- /**给表单添加事件。
- * @method addEvent
- * @static
- * @param {String} type - 事件名称,参考本API Classer->FormComponents->Form的事件
- * @param {Function} event - 事件方法。
- * @example
- this.form.addEvent("afterLoad", function(){
- this.form.notice("表单载入完成", "success");
- }.bind(this));
- */
- "addEvent": function(type, event ){_form.addEvent(type, event );},
- /**用一个新的浏览器窗口来打开当前文档,用于打印。<b>(仅流程表单中可用)</b><br/>
- * 如不指定表单,则使用表单设计中指定的打印表单。<br/>
- * @method print
- * @static
- * @param {String} [application] - 指定表单所在的流程应用ID或名称。省略此参数表示当前应用。
- * @param {String} [form] - 指定表单ID或名称。
- * @example
- //在新窗口中使用当前表单中配置的打印表单打开当前文档
- this.form.print();
- * @example
- //在新窗口中使用“订单打印表单”表单打开当前文档
- this.form.print("订单打印表单");
- * @example
- //在新窗口中使用“订单管理”应用中的“订单打印表单”表单打开当前文档
- this.form.print("订单管理", "订单打印表单");
- */
- "print": function(application, form){
- if (arguments.length){
- var app = (arguments.length>1) ? arguments[0] : null;
- var formName = (arguments.length>1) ? arguments[1] : arguments[0];
- _form.printWork(app, formName);
- }else{
- _form.printWork();
- }
- },
- /**同print方法。<b>(仅流程表单中可用)</b><br/>
- * @method openWindow
- * @static
- * @see this.form.print()
- * @param {String} [application] - 指定表单所在的流程应用ID或名称。省略此参数表示当前应用。
- * @param {String} [form] - 指定表单ID或名称。
- * @example
- this.form.openWindow();
- */
- "openWindow": function(application, form){
- if (arguments.length){
- var app = (arguments.length>1) ? arguments[0] : null;
- var formName = (arguments.length>1) ? arguments[1] : arguments[0];
- _form.openWindow(formName, app);
- }else{
- _form.openWindow();
- }
- },
- /** 打开一个在流转或已完成的流程实例。<br/>
- * @method openWork
- * @static
- * @param {String} [workId] - 在流转的流程实例ID。workId和workCompletedId两个参数必须提供其中一个
- * @param {String} [workCompletedId] - 已完成的流程实例ID。
- * @param {String} [title] - 手机端打开时的窗口标题。
- * @param {Object} [options] - 其他选项,如只读参数。
- * @example
- * this.form.openWork(id, "", "work title");
- * @example
- * //以只读方式打开
- * this.form.openWork(id, "", "work title", {
- * readonly : true
- * });
- */
- "openWork": function(workId, workCompletedId, title, options){
- var op = options || {};
- op.workId = workId;
- op.workCompletedId = workCompletedId;
- op.docTitle = title;
- op.appId = "process.Work"+(op.workId || op.workCompletedId);
- return layout.desktop.openApplication(this.event, "process.Work", op);
- },
- /** 使用流程的jobId打开工作。<br/>
- * @method openJob
- * @static
- * @param {String} id - 流程的jobId,如果流程拆分后,有多个流程实例(workId会有多个),但jobId是唯一的。
- * @param {Boolean} [choice] - 如果有多个流程实例,是否弹出界面选择。如果传入false,则直接打开第一个工作。
- * @param {Object} [options] - 打开工作时传入的选项。
- * @param {Function} [callback] - 打开工作成功或失败的回调方法,如果打开成功,该方法可以获取打开的工作的对象(桌面模式)或窗口句柄(浏览器页签模式);如果打开失败,此方法第一个参数是一个Error,其cause属性可获取通过jobId查询到的work数据。
- * @example
- this.form.openJob(jobId, true);
- * @example
- this.form.openJob(jobId, true, {}, function(handel){
- //通过Error.prototype.isPrototypeOf(handel)来判断handel是否是一个错误。
- //如果打开成功,handel为打开的工作的对象(桌面模式)或窗口句柄(浏览器页签模式)
- //如果打开错误,handel为为一个Error对象,其cause属性可获取通过jobId查询到的work数据
- });
- */
- "openJob": function(id, choice, options, callback){
- var workData = null, handel;
- o2.Actions.get("x_processplatform_assemble_surface").listWorkByJob(id, function(json){
- if (json.data) workData = json.data;
- }.bind(this), null, false);
- if( !layout.inBrowser && o2.typeOf(callback) === "function" ){
- if( !options )options = {};
- var queryLoad = options.onQueryLoad;
- options.onQueryLoad = function () {
- if( o2.typeOf(queryLoad) === "function" )queryLoad.call(this);
- callback(this);
- }
- }
- runCallback = function ( handel ) {
- if( o2.typeOf(callback) === "function" ) {
- if (layout.inBrowser) {
- callback(handel);
- } else if (options && options.appId) {
- if (layout.desktop && layout.desktop.apps && layout.desktop.apps[options.appId]) {
- callback(layout.desktop.apps[options.appId], true);
- }else{
- callback(handel, false);
- }
- }else{
- callback(handel, false);
- }
- }
- };
- if (workData){
- var len = workData.workList.length + workData.workCompletedList.length;
- if (len){
- if (len>1 && choice){
- var node = new Element("div", {"styles": {"padding": "20px", "width": "500px"}}).inject(_form.node);
- workData.workList.each(function(work){
- var workNode = new Element("div", {
- "styles": {
- "background": "#ffffff",
- "border-radius": "10px",
- "clear": "both",
- "margin-bottom": "10px",
- "height": "40px",
- "padding": "10px 10px"
- }
- }).inject(node);
- var html = "<div style='height: 40px; width: 40px; float: left; background: url(../x_component_process_Xform/$Form/default/icon/work.png) no-repeat center center'></div>" +
- "<div style='height: 40px; width: 40px; float: right'><div class='MWFAction' style='height: 20px; width: 40px; margin-top: 10px; border: 1px solid #999999; border-radius: 5px;text-align: center; cursor: pointer'>"+o2.LP.widget.open+"</div></div>"+
- "<div style='height: 20px; line-height: 20px; margin: 0px 40px'>"+work.title+"</div>" +
- "<div style='margin: 0px 40px'><div style='color:#999999; float: left; margin-right: 10px'>"+work.activityName+"</div>" +
- "<div style='color:#999999; float: left; margin-right: 10px'>"+work.activityArrivedTime+"</div>" +
- "<div style='color:#999999; float: left; margin-right: 10px'>"+(work.manualTaskIdentityText || "")+"</div></div>";
- workNode.set("html", html);
- var action = workNode.getElement(".MWFAction");
- action.store("work", work);
- action.addEvent("click", function(e){
- var work = e.target.retrieve("work");
- if (work){
- handel = this.openWork(work.id, null, work.title, options);
- runCallback( handel );
- }
- dlg.close();
- }.bind(this));
- }.bind(this));
- workData.workCompletedList.each(function(work){
- var workNode = new Element("div", {
- "styles": {
- "background": "#ffffff",
- "border-radius": "10px",
- "clear": "both",
- "margin-bottom": "10px",
- "height": "40px",
- "padding": "10px 10px"
- }
- }).inject(node);
- var html = "<div style='height: 40px; width: 40px; float: left; background: url(../x_component_process_Xform/$Form/default/icon/work.png) no-repeat center center'></div>" +
- "<div style='height: 40px; width: 40px; float: right'><div class='MWFAction' style='height: 20px; width: 40px; margin-top: 10px; border: 1px solid #999999; border-radius: 5px;text-align: center; cursor: pointer'>"+o2.LP.widget.open+"</div></div>"+
- "<div style='height: 20px; line-height: 20px; margin: 0px 40px'>"+work.title+"</div>" +
- "<div style='margin: 0px 40px'><div style='color:#999999; float: left; margin-right: 10px'>"+o2.LP.widget.workcompleted+"</div>" +
- "<div style='color:#999999; float: left; margin-right: 10px'>"+work.completedTime+"</div>";
- workNode.set("html", html);
- var action = workNode.getElement(".MWFAction");
- action.store("work", work);
- action.addEvent("click", function(e){
- var work = e.target.retrieve("work");
- if (work){
- handel = this.openWork(null, work.id, work.title, options);
- runCallback( handel );
- }
- dlg.close();
- }.bind(this));
- }.bind(this));
- var height = node.getSize().y+20;
- if (height>600) height = 600;
- var dlg = o2.DL.open({
- "title": o2.LP.widget.choiceWork,
- "style" : "user",
- "isResize": false,
- "content": node,
- "buttonList": [
- {
- "type" : "cancel",
- "text": o2.LP.widget.close,
- "action": function(){dlg.close();}
- }
- ]
- });
- }else{
- if (workData.workList.length){
- var work = workData.workList[0];
- handel = this.openWork(work.id, null, work.title, options);
- runCallback( handel );
- return handel;
- }else{
- var work = workData.workCompletedList[0];
- handel = this.openWork(null, work.id, work.title, options);
- runCallback( handel );
- return handel;
- }
- }
- }else{
- runCallback(new Error("Can't open this Job", {
- cause: workData
- }));
- }
- }else{
- runCallback(new Error("Can't open this Job", {
- cause: workData
- }));
- }
- // var op = options || {};
- // op.workId = id;
- // op.workCompletedId = completedId;
- // op.docTitle = title;
- // op.appId = "process.Work"+(op.workId || op.workCompletedId);
- // layout.desktop.openApplication(this.event, "process.Work", op);
- },
- /** 打开一个内容管理文档。<br/>
- * @method openDocument
- * @static
- * @param {String} id - 内容管理文档实例的ID。
- * @param {Boolean} [title] - 手机APP端打开时的窗口标题。
- * @param {Object} [options] - 其他参数,内容如下<br>
- * <pre><code class="language-js">{
- * "readonly": true, //是否以只读方式打开,默认为true
- * "forceFormId": "xxxxxx", //不管编辑还是阅读都用此表单id打开,优先使用。6.0版本之前使用 printFormId。
- * "readFormId": "xxxxxx", //强制的阅读表单id,优先于表单的readFormId。6.0版本之前使用 formId。
- * "editFormId": "xxxxxx", //强制的编辑表单id,优先于表单的formId。6.0版本之前使用 formEditId。
- * "saveOnClose" : true, //关闭草稿的时候是否自动保存
- * "onPostPublish" : function( documentData ){ //发布前执行方法,但数据已经准备好,该事件在桌面模式打开有效
- * //documentData 为文档数据
- * },
- * "onAfterPublish" : function( form, documentData ){ //发布后执行的方法,该事件在桌面模式打开有效
- * //form为内容管理Form对象,documentData 为文档数据
- * },
- * "onAfterSave": function( form, documentData ){ //保存后执行的方法,该事件在桌面模式打开有效
- * //form为内容管理Form对象,documentData 为文档数据
- * },
- * "onBeforeClose": function(){ //关闭前执行的方法,该事件在桌面模式打开有效
- *
- * },
- * "onPostDelete" : function(){ //删除文档后执行的方法,该事件在桌面模式打开有效
- * }
- * }</code></pre>
- * @example
- this.form.openDocument(id, "document title");
- */
- "openDocument": function(id, title, options){
- var op = options || {};
- op.documentId = id;
- op.docTitle = title || "";
- op.appId = (op.appId) || ("cms.Document"+id);
- if( op.onPostPublish ){
- op.postPublish = op.onPostPublish;
- delete op.onPostPublish;
- }
- if( op.onAfterPublish ){
- op.afterPublish = op.onAfterPublish;
- delete op.onAfterPublish;
- }
- if( op.onAfterSave ){
- op.afterSave = op.onAfterSave;
- delete op.onAfterSave;
- }
- if( op.onBeforeClose ){
- op.beforeClose = op.onBeforeClose;
- delete op.onBeforeClose;
- }
- if( op.onPostDelete ){
- op.postDelete = op.onPostDelete;
- delete op.onPostDelete;
- }
- return layout.desktop.openApplication(this.event, "cms.Document", op);
- },
- /**打开一个门户页面。<br/>
- * @method openPortal
- * @static
- * @param {String} portal - 要打开的门户应用名称、别名或ID。
- * @param {String} [page] - 要打开的页面名称、别名或ID。如果忽略,则打开门户的默认首页
- * @param {Object} [par] - 打开页面可以传入参数。<br>在被打开的页面中,可以通过脚本this.page.parameters访问到此参数。
- * @example
- this.form.openPortal(id, "", {"type": "my type"});
- */
- "openPortal": function (portal, page, par) {
- var action = MWF.Actions.get("x_portal_assemble_surface");
- action.getApplication(portal, function (json) {
- if (json.data) {
- if (page) {
- action.getPageByName(page, json.data.id, function (pageJson) {
- var pageId = (pageJson.data) ? pageJson.data.id : "";
- layout.desktop.openApplication(null, "portal.Portal", {
- "portalId": json.data.id,
- "pageId": pageId,
- "parameters": par,
- "appId": (par && par.appId) || ("portal.Portal" + json.data.id + pageId)
- })
- });
- } else {
- layout.desktop.openApplication(null, "portal.Portal", {
- "portalId": json.data.id,
- "parameters": par,
- "appId": (par && par.appId) || ("portal.Portal" + json.data.id)
- })
- }
- }
- });
- },
- /**打开一个内容管理栏目(应用)。<br/>
- * @method openCMS
- * @static
- * @param {String} name - 内容管理栏目的名称、别名或ID。
- * @example
- this.form.openCMS("通知公告");
- */
- "openCMS": function(name){
- var action = MWF.Actions.get("x_cms_assemble_control");
- action.getColumn(name, function(json){
- if (json.data){
- layout.desktop.openApplication(null, "cms.Module", {
- "columnId": json.data.id,
- "appId": "cms.Module"+json.data.id
- });
- }
- });
- },
- /**打开一个流程应用。<br/>
- * @method openProcess
- * @static
- * @param {String} name - 流程应用的名称、别名或ID。
- * @example
- this.form.openProcess("财务审批");
- */
- "openProcess": function(name){
- var action = MWF.Actions.get("x_processplatform_assemble_surface");
- action.getApplication(name, function(json){
- if (json.data){
- layout.desktop.openApplication(null, "process.Application", {
- "id": json.data.id,
- "appId": "process.Application"+json.data.id
- });
- }
- });
- },
- /**打开任意一个component应用。<br/>
- * @method openApplication
- * @static
- * @param {String} name - 要打开的component的名称。component对应的名称可以在“控制面板-系统设置-界面设置-模块部署”中找到(即“组件路径”)。
- * @param {Object} [options] - 打开的component的相关参数,对应该应用源码Main.js中的的options。
- * @param {Object} [status] - 打开的component的状态,对应用户的操作后的状态。<b>请按照下面的方式获取该参数:</b>双击桌面模式的应用,在打开应用的浏览器地址上可以查到对应的status。
- * @example
- //打开会议管理
- this.form.openApplication("Meeting");
- * @example
- //打开会议管理的周视图
- this.form.openApplication("Meeting", null, {"action":"toWeek" });
- * @example
- //打开一个流转中的流程实例。与 this.form.openWork(id, "", "work title");效果相同
- this.form.openApplication("process.Work", {
- "workId": id, //流程实例ID
- "width": "1200", //宽度
- "height": "800", //高度
- "docTitle": "work title", //APP端窗口标题
- "appId": "process.Work"+id //给新打开的component实例一个唯一名称
- });
- */
- "openApplication":function(name, options, status){
- return layout.desktop.openApplication(null, name, options, status);
- },
- /**创建一条内容管理文档。
- * @method createDocument
- * @static
- * @param {(String|Object)} [columnOrOptions]
- * 如果不传参数,则弹出范围为平台所有栏目的选择界面。<br/>
- * 当使用String时为内容管理应用(栏目)的名称、别名或ID。<br/>
- * 当使用Object时,本参数后面的参数省略,传入如下格式的内容:
- * <pre><code class="language-js">{
- * "column" : column, //(string)可选,内容管理应用(栏目)的名称、别名或ID
- * "category" : category, //(string)可选,要创建的文档所属的分类的名称、别名或ID
- * "data" : data, //(json object)可选,创建文档时默认的业务数据
- * "identity" : identity, //(string | Array)可选,创建文档所使用的身份。如果此参数为空,且当前人有多个身份的情况下,会弹出身份选择对话框;如果此参数为数组,则弹出数组范围内的身份供选择;否则使用默认身份。
- * "callback" : callback, //(funcation)可选,文档创建后的回调函数。
- * "target" : target, //(boolean)可选,为true时,在当前页面打开创建的文档;否则打开新窗口。默认false。(当前表单或页面在浏览器单独打开的时候该参数有效。)
- * "latest" : latest, //(boolean)可选,为true时,如果当前用户已经创建了此分类的文档,并且没有发布过,直接调用此文档为新文档;否则创建一个新文档。默认true。
- * "selectColumnEnable" : selectColumnEnable, //(boolean)可选,是否可以选择应用和分类进行创建文档。有category参数时为默认false,否则默认为true。
- * "ignoreTitle" : ignoreTitle //(boolean)可选,值为false时,创建的时候需要强制填写标题,默认为false。
- * "restrictToColumn" : restrictToColumn //(boolean)可选,值为true时,会限制在传入的栏目中选择分类,默认为false。
- * }</code></pre>
- * @param {String} [category] - 要创建的文档所属的分类的名称、别名或ID
- * @param {Object} [data] - 创建文档时默认的业务数据
- * @param {String} [identity | Array] - 可选,创建文档所使用的身份。如果此参数为空,且当前人有多个身份的情况下,会弹出身份选择对话框;如果此参数为数组,则弹出数组范围内的身份供选择;否则使用默认身份。
- * @param {Function} [callback] - 文档创建后的回调函数
- * @param {Boolean} [target] - 为true时,在当前页面打开创建的文档;否则打开新窗口。默认false。(当前表单或页面在浏览器单独打开的时候该参数有效。)
- * @param {Boolean} [latest] - 为true时,如果当前用户已经创建了此分类的文档,并且没有发布过,直接调用此文档为新文档;否则创建一个新文档。默认true。
- * @param {Boolean} [selectColumnEnable] - 是否可以选择应用和分类进行创建文档。有category参数时为默认false,否则默认为true。
- * @param {Boolean} [ignoreTitle] - 值为false时,创建的时候需要强制填写标题,默认为false。
- * @param {Boolean} [restrictToColumn] - 值为true时,会限制在传入的栏目中选择分类,默认为false。
- * @example
- //启动一个通知公告
- this.form.createDocument("", "通知公告");
- * @example
- //启动一个通知公告,标题为:关于XX的通知,启动后提示
- this.form.createDocument("", "通知公告", {"subject": "关于XX的通知"}, function(json){
- this.form.notice("创建成功!", "success");
- }.bind(this));
- * @example
- //启动一个通知公告,标题为:关于XX的通知,启动后提示
- this.form.createDocument({
- category : "通知公告",
- data : {"subject": "关于XX的通知"},
- callback : function(documentId, json, documentApp){
- if( layout.inBrowser ){ //浏览器模式
- //documentApp 为文档的window对象
- }else{
- //documentApp 为文档document app对象
- }
- this.form.notice("创建成功!", "success");
- }.bind(this)
- });
- */
- "createDocument": function (columnOrOptions, category, data, identity, callback, target, latest, selectColumnEnable, ignoreTitle, restrictToColumn) {
- var column = columnOrOptions;
- var onAfterPublish, onPostPublish;
- if (typeOf(columnOrOptions) == "object") {
- column = columnOrOptions.column;
- category = columnOrOptions.category;
- data = columnOrOptions.data;
- identity = columnOrOptions.identity;
- callback = columnOrOptions.callback;
- target = columnOrOptions.target;
- latest = columnOrOptions.latest;
- selectColumnEnable = columnOrOptions.selectColumnEnable;
- ignoreTitle = columnOrOptions.ignoreTitle;
- restrictToColumn = columnOrOptions.restrictToColumn;
- onAfterPublish = columnOrOptions.onAfterPublish;
- onPostPublish = columnOrOptions.onPostPublish;
- }
- if (target) {
- if (layout.app && layout.app.inBrowser) {
- layout.app.content.empty();
- layout.app = null;
- }
- }
- MWF.xDesktop.requireApp("cms.Index", "Newer", function () {
- var starter = new MWF.xApplication.cms.Index.Newer(null, null, _form.app, null, {
- "documentData": data,
- "identity": identity,
- "ignoreTitle": ignoreTitle === true,
- "ignoreDrafted": latest === false,
- "selectColumnEnable": !category || selectColumnEnable === true,
- "restrictToColumn": restrictToColumn === true || (!!category && selectColumnEnable !== true),
- "categoryFlag": category, //category id or name
- "columnFlag": column, //column id or name,
- "onStarted": function (documentId, data, windowHandle) {
- if (callback) callback(documentId, data, windowHandle);
- },
- "onPostPublish": function () {
- if(onPostPublish)onPostPublish();
- },
- "onAfterPublish": function () {
- if(onAfterPublish)onAfterPublish();
- }
- });
- starter.load();
- })
- },
- /**启动一个流程实例。如果不传参数则弹出流程启动界面,显示当前用户有权限启动的流程。如果传入app则弹出流程启动界面,显示app对应的的流程。如果传入app和process则直接发起流程。<br/>
- * @method startProcess
- * @static
- * @param {String|Array} [app] - 流程应用的名称、别名或ID。
- * @param {String} [process] - 要启动的流程的名称、别名或ID。
- * @param {Object} [data] - 流程启动时默认的业务数据。
- * @param {String | Array} [identity] - 流程启动所使用的身份。如果此参数为空/空字符串,且当前人有多个身份的情况下,会弹出身份选择对话框;如果此参数为数组,则弹出数组范围内的身份供选择;否则使用默认身份。
- * @param {Function} [callback] - 流程启动后的回调函数,可以获取到启动的数据。
- * @param {Boolean} [target] - 为true时,在当前页面打开启动的流程实例;否则打开新窗口。默认false。(当前表单或页面在浏览器单独打开的时候该参数有效。)
- * @param {Boolean} [latest] - 为true时,如果当前用户已经创建了此流程的实例,并且没有流转过,直接调用此实例为新流程实例;否则创建一个新实例。默认false。
- * @param {Function} [afterCreated] - 流程创建后的回调,可以获取到创建的流程Work对象(桌面模式)或者Window对象(浏览器模式)。
- * @param {Boolean} [skipDraftCheck] - 是否跳过新建检查(默认根据流程的新建检查配置),设置true则不进行新建检查。
- * @example
- * //弹出流程发起界面
- * this.form.startProcess();
- * @example
- * //弹出公文管理发起界面
- * this.form.startProcess("公文管理");
- * @example
- * //弹出公文管理和人事管理的发起界面
- * this.form.startProcess(["公文管理","人事管理"]);
- * @example
- * //启动一个发文管理实例
- this.form.startProcess("公文管理", "发文管理");
- * @example
- * //启动一个发文管理实例,标题为:my file title,启动后提示
- * this.form.startProcess("公文管理", "发文管理", {"title": "my file title"}, "张三@kfb_zhangsan@I", function(json){
- * this.form.notice("create file success!", "success");
- * }, false, false, function(workApp){
- * if( layout.inBrowser ){ //浏览器模式
- * //workApp 为流程的window对象
- * }else{
- * //workApp 为流程Work app对象
- * }
- * });
- */
- "startProcess": function(app, process, data, identity, callback, target, latest, afterCreated, skipDraftCheck){
- if (arguments.length>2){
- for (var i=2; i<arguments.length; i++){
- if (typeOf(arguments[i])=="boolean"){
- target = arguments[i];
- break;
- }
- }
- }
- if (target){
- if (layout.app && layout.app.inBrowser){
- //layout.app.content.empty();
- layout.app.$openWithSelf = true;
- }
- }
- if (!app || !process){
- var cmpt = this.getApp();
- o2.requireApp([["process.TaskCenter", "lp."+o2.language], ["process.TaskCenter", ""]],"", function(){
- var obj = {
- "lp": o2.xApplication.process.TaskCenter.LP,
- "content": cmpt.content,
- "addEvent": function(type, fun){
- cmpt.addEvent(type, fun);
- },
- "getAction": function (callback) {
- if (!this.action) {
- this.action = o2.Actions.get("x_processplatform_assemble_surface");
- if (callback) callback();
- } else {
- if (callback) callback();
- }
- },
- "desktop": layout.desktop,
- "refreshAll": function(){},
- "notice": cmpt.notice,
- }
- o2.JSON.get("../x_component_process_TaskCenter/$Main/default/css.wcss", function(data){
- obj.css = data;
- }, false);
- if (!cmpt.processStarter) cmpt.processStarter = new o2.xApplication.process.TaskCenter.Starter(obj);
- cmpt.processStarter.load({
- "appFlag": app
- });
- }, true, true);
- return "";
- }
- MWF.xDesktop.requireApp("process.TaskCenter", "ProcessStarter", null, false);
- var action = MWF.Actions.get("x_processplatform_assemble_surface").getProcessByName(process, app, function(json){
- if (json.data){
- var starter = new MWF.xApplication.process.TaskCenter.ProcessStarter(json.data, _form.app, {
- "workData": data,
- "identity": identity,
- "latest": latest,
- "skipDraftCheck": skipDraftCheck,
- "onStarted": function(data, title, processName){
- var application;
- if (data.work){
- var work = data.work;
- var options = {
- "draft": work,
- "draftData":data.data||{},
- "appId": "process.Work"+(new o2.widget.UUID).toString(),
- "desktopReload": false
- };
- if( !layout.inBrowser && afterCreated )options.onPostLoadForm = afterCreated;
- application = layout.desktop.openApplication(null, "process.Work", options);
- }else{
- var currentTask = [];
- data.each(function(work){
- if (work.currentTaskIndex != -1) currentTask.push(work.taskList[work.currentTaskIndex].work);
- }.bind(this));
- if (currentTask.length==1){
- var options = {"workId": currentTask[0], "appId": currentTask[0]};
- if( !layout.inBrowser && afterCreated )options.onPostLoadForm = afterCreated;
- application = layout.desktop.openApplication(null, "process.Work", options);
- }else{}
- }
- if (callback) callback(data);
- if(layout.inBrowser && afterCreated){
- afterCreated(application)
- }
- }.bind(this)
- });
- starter.load();
- }
- });
- }
- };
- /**
- * 获取表单是否可编辑。只读。
- * @member readonly
- * @static
- * @return {Boolean} 是否只读.
- * @o2syntax
- * var readonly = this.form.readonly;
- */
- Object.defineProperty(this.form, "readonly", {
- get: function(){ return !!_form.options.readonly; }
- });
- /**
- * 在用户提交的时候,选择的路由。仅在表单的“校验意见”和“校验路由”脚本中可用。只读。<b>(仅流程表单中可用)</b>。
- * @member currentRouteName
- * @memberOf module:form
- * @static
- * @return {String} 用户选择的路由。
- * @o2syntax
- * var currentRouteName = this.form.currentRouteName;
- */
- //this.form.currentRouteName = _form.json.currentRouteName;
- /**
- * 在用户提交的时候,选择的路由别名。仅在表单的“校验意见”和“校验路由”脚本中可用。只读。<b>(仅流程表单中可用)</b>。
- * @member currentRouteAlias
- * @memberOf module:form
- * @static
- * @return {String} 用户选择的路由别名。
- * @o2syntax
- * var currentRouteAlias = this.form.currentRouteAlias;
- */
- //this.form.currentRouteAlias = _form.json.currentRouteAlias;
- /**
- * 在用户提交的时候,输入的意见。仅在表单的“校验意见”和“校验路由”脚本中可用。只读。<b>(仅流程表单中可用)</b>。
- * @member opinion
- * @memberOf module:form
- * @static
- * @return {String} 用户填写的意见.
- * @o2syntax
- * var opinion = this.form.opinion;
- */
- //this.form.opinion = _form.json.opinion;
- /**
- * 在提交的时候,用户的手写意见以及录音意见,仅在表单的“校验意见”和“校验路由”脚本中可用。只读。<b>(仅流程表单中可用)</b>。
- * @member medias
- * @memberOf module:form
- * @static
- * @return {Blob[]} 手写意见以及录音意见数组。手写意见和录音意见都是 HTML5的blob类型文件。
- * @o2syntax
- * var medias = this.form.medias;
- */
- this.form.medias = [];
- this.target = ev.target;
- this.event = ev.event;
- this.status = ev.status;
- this.session = layout.desktop.session;
- this.Actions = o2.Actions;
- this.query = function(option){
- // options = {
- // "name": "statementName",
- // "data": "json data",
- // "firstResult": 1,
- // "maxResults": 100,
- // "success": function(){},
- // "error": function(){},
- // "async": true or false, default is true
- // }
- if (option){
- var json = (option.data) || {};
- if (option.firstResult) json.firstResult = option.firstResult.toInt();
- if (option.maxResults) json.maxResults = option.maxResults.toInt();
- o2.Actions.get("x_query_assemble_surface").executeStatement(option.name, json, success, error, options.async);
- }
- }
- this.Table = MWF.xScript.createTable();
- };
- if( !MWF.xScript.createTable )MWF.xScript.createTable = function(){
- return function(name){
- this.name = name;
- this.action = o2.Actions.load("x_query_assemble_surface").TableAction;
- this.listRowNext = function(id, count, success, error, async){
- return this.action.listRowNext(this.name, id, count, success, error, async);
- };
- this.listRowPrev = function(id, count, success, error, async){
- return this.action.listRowPrev(this.name, id, count, success, error, async);
- };
- this.listRowSelect = function(where, orderBy, size, success, error, async){
- return this.action.listRowSelect(this.name, {"where": where, "orderBy": orderBy, "size": size || ""}, success, error, async);
- };
- this.listRowSelectWhere = function(where, success, error, async){
- return this.action.listRowSelectWhere(this.name, where, success, error, async);
- };
- this.rowCountWhere = function(where, success, error, async){
- return this.action.rowCountWhere(this.name, where, success, error, async);
- };
- this.deleteRow = function(id, success, error, async){
- return this.action.rowDelete(this.name, id, success, error, async);
- };
- this.deleteAllRow = function(success, error, async){
- return this.action.rowDeleteAll(this.name, success, error, async);
- };
- this.getRow = function(id, success, error, async){
- return this.action.rowGet(this.name, id, success, error, async);
- };
- this.insertRow = function(data, success, error, async){
- return this.action.rowInsert(this.name, data, success, error, async);
- };
- this.addRow = function(data, success, error, async){
- return this.action.rowInsertOne(this.name, data, success, error, async);
- };
- this.updateRow = function(id, data, success, error, async){
- return this.action.rowUpdate(this.name, id, data, success, error, async);
- };
- this.partUpdateRow = function(id, data, success, error, async){
- return this.action.rowPartUpdate(this.name, id, data, success, error, async);
- };
- }
- };
- var getArrayJSONData = function(jData, p, _form){
- return new MWF.xScript.JSONData(jData, function(data, key, _self){
- var p = {"getKey": function(){return key;}, "getParent": function(){return _self;}};
- while (p && !_form.forms[p.getKey()]) p = p.getParent();
- //if (p) if (p.getKey()) if (_forms[p.getKey()]) _forms[p.getKey()].resetData();
- var k = (p) ? p.getKey() : "";
- if (k) if(_form.forms[k]) if(_form.forms[k].resetData) _form.forms[k].resetData();
- //if(p) if(p.getKey()) if(_forms[p.getKey()]) if(_forms[p.getKey()].render) _forms[p.getKey()].render();
- }, "", p, _form);
- };
- if ( !MWF.xScript.JSONData )MWF.xScript.JSONData = function(data, callback, key, parent, _form){
- var getter = function(data, callback, k, _self){
- return function(){
- var t = typeOf(data[k]);
- if (["array","object"].indexOf(t)===-1){
- return data[k]
- }else{
- if (t==="array"){
- //if (!MWF.xScript.ArrayData){
- // var ArrayData = function(data, callback, key, parent, _form){
- // MWF.xScript.JSONData.call(this, data, callback, key, parent, _form);
- // Array.call(this, data);
- // };
- // Object.assign(ArrayData.prototype, MWF.xScript.JSONData.prototype);
- // Object.assign(ArrayData.prototype, Array.prototype);
- //}
- //return new MWF.xScript.ArrayData(data[k], callback, k, _self, _form);
- //return new ArrayData(data[k], callback, k, _self, _form)
- // var arr = Array.clone(data[k]);
- // for (x in arr){
- // if (typeof x === 'number' && !isNaN(x)){
- // arr
- // }
- // }
- //return data[k];
- if (window.Proxy){
- var arr = new Proxy(data[k], {
- get: function(o, k){
- return (o2.typeOf(o[k])==="object") ? getArrayJSONData(o[k], _self, _form) : o[k];
- },
- set: function(o, k, v){
- o[k] = v;
- if (callback) callback(o, k, _self);
- return true;
- }
- });
- return arr;
- }else{
- var arr =[];
- data[k].forEach(function(d, i){
- arr.push((o2.typeOf(d)==="object") ? getArrayJSONData(d, _self, _form) : d);
- });
- return arr;
- }
- // var arr =[];
- // data[k].forEach(function(d, i){
- // arr.push((o2.typeOf(d)==="object") ? getArrayJSONData(d, _self, _form) : d);
- // });
- // return arr;
- //return getArrayJSONData(data[k], _self, _form);
- }else{
- return new MWF.xScript.JSONData(data[k], callback, k, _self, _form);
- }
- // var obj =
- // if (t==="array") obj.constructor = Array;
- // return obj;
- }
- //return (["array","object"].indexOf(typeOf(data[k]))===-1) ? data[k] : new MWF.xScript.JSONData(data[k], callback, k, _self, _form);
- };
- };
- var setter = function(data, callback, k, _self){
- return function(v){
- data[k] = v;
- //debugger;
- //this.add(k, v, true);
- if (callback) callback(data, k, _self);
- }
- };
- var define = function(){
- var o = {};
- for (var k in data) o[k] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, k, this]),"set": setter.apply(this, [data, callback, k, this])};
- o["length"] = {"get": function(){return Object.keys(data).length;}};
- o["some"] = {"get": function(){return data.some;}};
- MWF.defineProperties(this, o);
- var methods = {
- "getKey": {"value": function(){ return key; }},
- "getParent": {"value": function(){ return parent; }},
- "toString": {"value": function() { return data.toString();}},
- "setSection": {"value": function(newKey, newValue){
- this.add(newKey, newValue, true);
- try {
- var path = [this.getKey()];
- p = this.getParent();
- while (p && p.getKey()){
- path.unshift(p.getKey());
- p = p.getParent();
- }
- if (path.length) _form.sectionListObj[path.join(".")] = newKey;
- }catch(e){
- }
- }},
- "add": {"value": function(newKey, newValue, overwrite, noreset){
- if( newKey.test(/^\d+$/) ){
- throw new Error("Field name '"+newKey+"' cannot contain only numbers" );
- }
- if (arguments.length<2 || newKey.indexOf("..")===-1){
- var flag = true;
- var type = typeOf(data);
- if (type==="array"){
- if (arguments.length<2){
- data.push(newKey);
- newValue = newKey;
- newKey = data.length-1;
- }else{
- if (!newKey && newKey!==0){
- data.push(newValue);
- newKey = data.length-1;
- }else{
- if (newKey>=data.length){
- data.push(newValue);
- newKey = data.length-1;
- }else{
- if (overwrite) data[newKey] = newValue;
- newValue = data[newKey];
- flag = false;
- }
- }
- }
- if (flag){
- var o = {};
- o[newKey] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, newKey, this]),"set": setter.apply(this, [data, callback, newKey, this])};
- MWF.defineProperties(this, o);
- }
- if (!noreset) this[newKey] = newValue;
- }else if (type==="object"){
- if (!this.hasOwnProperty(newKey)){
- if (!data[newKey] || overwrite){
- data[newKey] = newValue;
- }
- newValue = data[newKey];
- if (flag){
- var o = {};
- o[newKey] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, newKey, this]),"set": setter.apply(this, [data, callback, newKey, this])};
- MWF.defineProperties(this, o);
- }
- if (!noreset) this[newKey] = newValue;
- }else{
- if (!Object.getOwnPropertyDescriptor(this, newKey).get){
- var o = {};
- o[newKey] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, newKey, this]),"set": setter.apply(this, [data, callback, newKey, this])};
- MWF.defineProperties(this, o);
- }
- if (overwrite){
- data[newKey] = newValue;
- if (!noreset) this[newKey] = newValue;
- }
- }
- }
- return this[newKey];
- }else{
- var keys = newKey.split("..");
- var kk = keys.shift();
- var d = this.add(kk, {}, false, true);
- if (keys.length) return d.add(keys.join(".."), newValue, overwrite, noreset);
- return d;
- }
- }},
- "check": {
- "value": function(kk, v){
- var value = typeOf( v ) === "null" ? "" : v;
- this.add(kk, value, false, true);
- }
- },
- "del": {"value": function(delKey){
- if (!this.hasOwnProperty(delKey)) return null;
- // delete data[delKey];
- // delete this[delKey];
- data[delKey] = "";
- this[delKey] = "";
- return this;
- }}
- };
- MWF.defineProperties(this, methods);
- //this.getKey = function(){ return key; };
- //this.getParent = function(){ return parent; };
- //this.toString = function() { return data.toString();};
- //this.add = function(newKey, newValue, overwrite){
- // var flag = true;
- // var type = typeOf(data);
- // if (!this.hasOwnProperty(newKey)){
- // if (type=="array"){
- // if (arguments.length<2){
- // data.push(newKey);
- // newValue = newKey;
- // newKey = data.length-1;
- // }else{
- // debugger;
- // if (!newKey && newKey!=0){
- // data.push(newValue);
- // newKey = data.length-1;
- // }else{
- // flag == false;
- // }
- // }
- // }else{
- // data[newKey] = newValue;
- // }
- // //var valueType = typeOf(newValue);
- // //var newValueData = newValue;
- // //if (valueType=="object" || valueType=="array") newValueData = new MWF.xScript.JSONData(newValue, callback, newKey, this);
- // //if (valueType=="null") newValueData = new MWF.xScript.JSONData({}, callback, newKey, this);
- // if (flag){
- // var o = {};
- // o[newKey] = {"configurable": true, "enumerable": true, "get": getter.apply(this, [data, callback, newKey, this]),"set": setter.apply(this, [data, callback, newKey, this])};
- // MWF.defineProperties(this, o);
- // }
- // this[newKey] = newValue;
- // }else{
- // if (overwrite) this[newKey] = newValue;
- // }
- //
- // //var valueType = typeOf(newValue);
- // //var newValueData = newValue;
- // //if (valueType=="object" || valueType=="array") newValueData = new MWF.xScript.JSONData(newValue, callback, newKey, this);
- // //if (valueType=="null") newValueData = new MWF.xScript.JSONData({}, callback, newKey, this);
- // //
- // //this[newKey] = newValueData;
- //
- // return this[newKey];
- //};
- //this.del = function(delKey){
- // if (!this.hasOwnProperty(delKey)) return null;
- // delete data[newKey];
- // delete this[newKey];
- // return this;
- //};
- };
- var type = typeOf(data);
- if (type==="object" || type==="array") define.apply(this);
- };
- //MWF.xScript.createDict = function(application){
- // return function(name){
- // var applicationId = application;
- // this.name = name;
- // //MWF.require("MWF.xScript.Actions.DictActions", null, false);
- // var action = MWF.Actions.get("x_processplatform_assemble_surface");
- //
- // this.get = function(path, success, failure){
- // debugger;
- // var value = null;
- // if (path){
- // var arr = path.split(/\./g);
- // var ar = arr.map(function(v){
- // return encodeURIComponent(v);
- // });
- // //var p = path.replace(/\./g, "/");
- // var p = ar.join("/");
- // action.getDictData(encodeURIComponent(this.name), applicationId, p, function(json){
- // value = json.data;
- // if (success) success(json.data);
- // }, function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // }, false);
- // }else{
- // action.getDictRoot(encodeURIComponent(this.name), applicationId, function(json){
- // value = json.data;
- // if (success) success(json.data);
- // }, function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // }, false);
- // }
- //
- // return value;
- // };
- //
- // this.set = function(path, value, success, failure){
- // var p = path.replace(/\./g, "/");
- // action.setDictData(encodeURIComponent(this.name), applicationId, p, value, function(json){
- // if (success) success(json.data);
- // }, function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // });
- // };
- // this.add = function(path, value, success, failure){
- // var p = path.replace(/\./g, "/");
- // action.addDictData(encodeURIComponent(this.name), applicationId, p, value, function(json){
- // if (success) success(json.data);
- // }, function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // });
- // };
- // this["delete"] = function(path, success, failure){
- // var p = path.replace(/\./g, "/");
- // action.deleteDictData(encodeURIComponent(this.name), applicationId, p, function(json){
- // if (success) success(json.data);
- // }, function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // });
- // };
- // this.destory = this["delete"];
- // }
- //};
- // var dictLoaded = {};
- if( !MWF.xScript.dictLoaded )MWF.xScript.dictLoaded = {};
- if( !MWF.xScript.createDict ){
- MWF.xScript.addDictToCache = function ( options, path, json ) {
- if( !path )path = "root";
- if( path.indexOf("root") !== 0 )path = "root." + path ;
- var type = options.appType || "process";
- var enableAnonymous = ( options.enableAnonymous || options.anonymous ) || false;
- var appFlagList = [];
- if( options.application )appFlagList.push( options.application );
- if( options.appId )appFlagList.push( options.appId );
- if( options.appName )appFlagList.push( options.appName );
- if( options.appAlias )appFlagList.push( options.appAlias );
- var dictFlagList = [];
- if( options.id )dictFlagList.push( options.id );
- if( options.name )dictFlagList.push( options.name );
- if( options.alias )dictFlagList.push( options.alias );
- var cache = {};
- cache[path] = json;
- for( var i=0; i<appFlagList.length; i++ ){
- for( var j=0; j<dictFlagList.length; j++ ){
- var k = dictFlagList[j] + type + appFlagList[i] + enableAnonymous;
- if( !MWF.xScript.dictLoaded[k] ){
- MWF.xScript.dictLoaded[k] = cache; //指向同一个对象
- // MWF.xScript.dictLoaded[k][path] = json; //指向不同的对象
- }else if( i===0 && j===0 ){
- MWF.xScript.setDictToCache( k, path ,json );
- var arr = path.split(/\./g);
- var p;
- var cache = MWF.xScript.dictLoaded[k];
- for( var l=0 ; l<arr.length; l++ ){
- p = l === 0 ? arr[0] : ( p + "." + arr[l] );
- if( cache[ p ] )break;
- }
- if( p ){
- var mathP = p+".";
- Object.keys( cache ).each( function( path, idx){
- if( path.indexOf( mathP ) === 0 )delete cache[path];
- })
- }
- }
- }
- }
- };
- MWF.xScript.getMatchedDict = function(key, path){
- if( !path )path = "root";
- if( path.indexOf("root") !== 0 )path = "root." + path ;
- var arr = path.split(/\./g);
- if( MWF.xScript.dictLoaded[key] ){
- var dicts = MWF.xScript.dictLoaded[key];
- var list = Array.clone(arr);
- var p;
- var dict;
- for( var i=0 ; i<arr.length; i++ ){
- p = i === 0 ? arr[0] : ( p + "." + arr[i] );
- list.shift();
- if( dicts[ p ] ){
- dict = dicts[ p ];
- break;
- }
- }
- return {
- dict : dict,
- unmatchedPathList : list
- }
- }
- return {
- dict : null,
- unmatchedPathList : list
- }
- };
- MWF.xScript.insertDictToCache = function(key, path, json){
- var p = path;
- if( !p )p = "root";
- if( p.indexOf("root") !== 0 )p = "root." + p ;
- if( MWF.xScript.dictLoaded[key] ){
- var matchedDict = MWF.xScript.getMatchedDict( key, path );
- var dict = matchedDict.dict;
- var list = matchedDict.unmatchedPathList;
- if( !dict ) {
- MWF.xScript.dictLoaded[key][p] = json;
- }else if( !list || list.length === 0 ){
- MWF.xScript.dictLoaded[key][p] = json;
- }else{
- for( var j=0; j<list.length-1; j++ ){
- if( !dict[ list[j] ] ){
- dict[ list[j] ] = {};
- }
- dict = dict[ list[j] ];
- }
- var lastPath = list[list.length-1];
- if( !dict[lastPath] ){
- dict[lastPath] = json;
- }else if( typeOf( dict[lastPath] ) === "array" ){
- dict[lastPath].push( json );
- }
- }
- }else{
- MWF.xScript.dictLoaded[key] = {};
- MWF.xScript.dictLoaded[key][p] = json;
- }
- };
- MWF.xScript.setDictToCache = function(key, path, json){
- var p = path;
- if( !p )p = "root";
- if( p.indexOf("root") !== 0 )p = "root." + p ;
- if( MWF.xScript.dictLoaded[key] ){
- var matchedDict = MWF.xScript.getMatchedDict( key, path );
- var dict = matchedDict.dict;
- var list = matchedDict.unmatchedPathList;
- if( !dict ){
- MWF.xScript.dictLoaded[key][p] = json;
- }else if( !list || list.length === 0 ){
- MWF.xScript.dictLoaded[key][p] = json;
- }else{
- for( var j=0; j<list.length-1; j++ ){
- if( !dict[ list[j] ] ){
- dict[ list[j] ] = {};
- }
- dict = dict[ list[j] ];
- }
- dict[list[list.length-1]] = json;
- }
- }else{
- MWF.xScript.dictLoaded[key] = {};
- MWF.xScript.dictLoaded[key][p] = json;
- }
- };
- MWF.xScript.getDictFromCache = function( key, path ){
- var matchedDict = MWF.xScript.getMatchedDict( key, path );
- var dict = matchedDict.dict;
- var list = matchedDict.unmatchedPathList;
- if( dict ){
- for( var j=0; j<list.length; j++ ){
- dict = dict[ list[j] ];
- if( !dict )return null;
- }
- return dict;
- }
- return null;
- };
- MWF.xScript.deleteDictToCache = function(key, path){
- var matchedDict = MWF.xScript.getMatchedDict( key, path );
- var dict = matchedDict.dict;
- var list = matchedDict.unmatchedPathList;
- if( dict){
- for( var j=0; j<list.length-1; j++ ){
- dict = dict[ list[j] ];
- if( !dict )return;
- }
- if( list.length ){
- delete dict[list[list.length-1]];
- }
- }
- };
- MWF.xScript.createDict = function(application, appType){
- //optionsOrName : {
- // type : "", //默认为process, 可以为 process cms portal
- // application : "", //流程/CMS的名称/别名/id, 默认为当前应用
- // name : "", // 数据字典名称/别名/id
- // anonymous : false //允许在未登录的情况下读取CMS的数据字典, 该参数名也可以是 enableAnonymous
- //}
- //或者name: "" // 数据字典名称/别名/id
- return function(optionsOrName){
- var options = optionsOrName;
- if( typeOf( options ) == "string" ){
- options = {
- name : options,
- type: appType,
- application: application
- };
- }
- var name = this.name = options.name;
- var type;
- if( options.type === "service"){
- type = options.type;
- }else{
- type = ( options.type && options.application ) ? options.type : "process";
- }
- var applicationId = options.application || application;
- var enableAnonymous = ( options.enableAnonymous || options.anonymous ) || false;
- var opt = {
- "appType" : type,
- "name" : name,
- "appId" : applicationId,
- "enableAnonymous" : enableAnonymous
- };
- var key = name+type+applicationId+enableAnonymous;
- // if (!dictLoaded[key]) dictLoaded[key] = {};
- // this.dictData = dictLoaded[key];
- //MWF.require("MWF.xScript.Actions.DictActions", null, false);
- var action;
- if( type === "cms" ) {
- action = MWF.Actions.get("x_cms_assemble_control");
- }else if( type === "portal" ){
- action = MWF.Actions.get("x_portal_assemble_surface");
- }else if( type === "service" ){
- key = name+type+enableAnonymous;
- action = MWF.Actions.get("x_program_center");
- }else{
- action = MWF.Actions.get("x_processplatform_assemble_surface");
- }
- var encodePath = function( path ){
- var arr = path.split(/\./g);
- var ar = arr.map(function(v){
- return encodeURIComponent(v);
- });
- return ( type === "portal" || type === "service" ) ? ar.join(".") : ar.join("/");
- };
- this.get = function(path, success, failure, async, refresh){
- var value = null;
- if (success===true) async=true;
- if (failure===true) async=true;
- if (!refresh ){
- var data = MWF.xScript.getDictFromCache( key, path );
- if( data ){
- if (success && o2.typeOf(success)=="function") success( data );
- if( !!async ){
- return Promise.resolve( data );
- }else{
- return data;
- }
- }
- }
- // var cb = function(json){
- // value = json.data;
- // MWF.xScript.addDictToCache(opt, path, value);
- // if (success && o2.typeOf(success)=="function") value = success(json.data);
- // return value;
- // }.ag().catch(function(xhr, text, error){ if (failure && o2.typeOf(failure)=="function") return failure(xhr, text, error); });
- var cb = function(json){
- value = json.data;
- MWF.xScript.addDictToCache(opt, path, value);
- if (success && o2.typeOf(success)=="function") value = success(json.data);
- return value;
- };
- var promise;
- if( type === "service" ){
- if (path){
- var p = encodePath( path );
- promise = action.getDictData(encodeURIComponent(this.name), p, cb, null, !!async, false);
- }else{
- promise = action.getDictRoot(this.name, cb, null, !!async, false);
- }
- }else{
- if (path){
- var p = encodePath( path );
- promise = action[ ( (enableAnonymous && type == "cms") ? "getDictDataAnonymous" : "getDictData" ) ](encodeURIComponent(this.name), applicationId, p, cb, null, !!async, false);
- }else{
- promise = action[ ( (enableAnonymous && type == "cms") ? "getDictRootAnonymous" : "getDictRoot" ) ](this.name, applicationId, cb, null, !!async, false);
- }
- }
- return (!!async) ? promise : value;
- // if (path){
- // var p = encodePath( path );
- // //var p = path.replace(/\./g, "/");
- // action[ ( (enableAnonymous && type == "cms") ? "getDictDataAnonymous" : "getDictData" ) ](encodeURIComponent(this.name), applicationId, p, function(json){
- // value = json.data;
- // // this.dictData[path] = value;
- // MWF.xScript.addDictToCache(opt, path, value);
- // if (success) success(json.data);
- // }.bind(this), function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // }, !!async);
- // }else{
- // action[ ( (enableAnonymous && type == "cms") ? "getDictRootAnonymous" : "getDictRoot" ) ](this.name, applicationId, function(json){
- // value = json.data;
- // // this.dictData["root"] = value;
- // MWF.xScript.addDictToCache(opt, path, value);
- // if (success) success(json.data);
- // }.bind(this), function(xhr, text, error){
- // if (failure) failure(xhr, text, error);
- // }, !!async);
- // }
- //return value;
- };
- this.set = function(path, value, success, failure){
- var p = encodePath( path );
- //var p = path.replace(/\./g, "/");
- var successCallback = function(json){
- MWF.xScript.setDictToCache(key, path, value);
- if (success) return success(json.data);
- };
- var failureCallback = function(xhr, text, error){
- if (failure) return failure(xhr, text, error);
- };
- if( type === "service" ){
- return action.setDictData(encodeURIComponent(this.name), p, value, successCallback, failureCallback, false, false);
- }else{
- return action.setDictData(encodeURIComponent(this.name), applicationId, p, value, successCallback, failureCallback, false, false);
- }
- };
- this.add = function(path, value, success, failure){
- var p = encodePath( path );
- //var p = path.replace(/\./g, "/");
- var successCallback = function(json){
- MWF.xScript.insertDictToCache(key, path, value);
- if (success) return success(json.data);
- };
- var failureCallback = function(xhr, text, error){
- if (failure) return failure(xhr, text, error);
- };
- if( type === "service" ) {
- return action.addDictData(encodeURIComponent(this.name), p, value, successCallback, failureCallback, false, false);
- }else{
- return action.addDictData(encodeURIComponent(this.name), applicationId, p, value, successCallback, failureCallback, false, false);
- }
- };
- this["delete"] = function(path, success, failure){
- var p = encodePath( path );
- //var p = path.replace(/\./g, "/");
- var successCallback = function(json){
- MWF.xScript.deleteDictToCache(key, path);
- if (success) return success(json.data);
- };
- var failureCallback = function(xhr, text, error){
- if (failure) return failure(xhr, text, error);
- };
- if( type === "service" ) {
- return action.deleteDictData(encodeURIComponent(this.name), p, successCallback, failureCallback, false, false);
- }else{
- return action.deleteDictData(encodeURIComponent(this.name), applicationId, p, successCallback, failureCallback, false, false);
- }
- };
- this.destory = this["delete"];
- }
- };
- }
|