12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830 |
- var CMSFunction = {
- ComboGrid: {
- SetValue: function (source, text, value) {
- var opts = $.data(source[0], "combogridX").options;
- if (text == "") {
- $(source).find('.combo-text').val(opts.emptyText);
- } else {
- $(source).find('.combo-text').val(text);
- }
- $(source).find('.combogridX-value').val(value);
- $(source).attr("loaded", "true");
-
- if ("undefined" != typeof EasyUIValidate) {
- if (EasyUIValidate.Events.ComboGridXOnChange) {
- EasyUIValidate.Events.ComboGridXOnChange.call(this);
- }
- }
- if (opts.onChange) opts.onChange.call(source);
- },
- OnLoadSuccessFunction: function (source, tableData, callBack) {
- var opts = $.data(source[0], "combogridX").options;
- var callbackCalled = false;
- var text = source.find(".combo-text").val();
- if (text == '' || text == null) {
- source.find('.combogridX-value').val("");
- }
- if (opts.value != '' && opts.value != -1 && $(source).attr("loaded") != "true") {
- var dataGrid = source.find('.easyui-cmsXDataTable');
- var jsonString = "({'QueryParamsDatas':'Attribute|*|{\"ID\":\"00000000-0000-0000-0000-000000000000\",\"Value\":\"" + opts.valueField
- + "\",\"ControlType\":\"TextBox\"}|@|Condition|*|=|@|ConditionValue|*|" + opts.value
- + "|@|" + opts.valueField + "_QueryTextBox|*|" + opts.value + "|@|',page: 0,rows: 10 })";
- try {
- var dataGridOptions = dataGrid.cmsXDataTable("options");
- var url = dataGridOptions.url;
- $.post(url, eval(jsonString), function (data) {
- if (data.rows.length > 0) {
- CMSFunction.ComboGrid.SetValue(source, data.rows[0][opts.textField], opts.value);
- if (callBack) {
- callbackCalled = true;
- callBack.call(source, tableData);
- }
- }
- });
- }
- catch (err) { }
- }
- var nowVal = source.find('.combogridX-value').val();
- if (!(nowVal && nowVal != "") && opts.selectedIndex != null && $(source).attr("loaded") != "true") {
- if (tableData.rows.length > opts.selectedIndex) {
- CMSFunction.ComboGrid.SetValue(source, tableData.rows[opts.selectedIndex][opts.textField], tableData.rows[opts.selectedIndex][opts.valueField]);
- }
- }
- //source.find(".combogridX-expander").width(source.find("table").width() + 16);
- source.find('tr.row>td').css("cursor", "pointer");
- source.find('tr.row').click(function () {
- var comboGrid = $(this).parents('.easyui-combogridX:first');
- var grid = $(this).parents('.easyui-cmsXDataTable:first');
- var opts = $.data(comboGrid[0], "combogridX").options;
- var gridOpts = $.data(grid[0], "cmsXDataTable").options;
- var gridData = gridOpts.data;
- var rowIndex = parseInt($(this).attr("xRowIndex"));
- var rowData = gridData.rows[rowIndex];
- CMSFunction.ComboGrid.SetValue(comboGrid, rowData[opts.textField], rowData[opts.valueField]);
- if (opts.onSelect) opts.onSelect.call(this, rowData);
- comboGrid.find(".combogridX-expander").css("display", "none");
- });
- var expander = source.find(".combogridX-expander");
- // expander.css("width", "");
- source.combogridX("setExpanderPosition", {
- expander: expander, dropdown: source, arrow: source.find('.combo-arrow')
- });
- if (callBack && !callbackCalled) {
- callBack.call(source, tableData);
- }
- }
- },
- Tree: {
- setParentsChecked: function (jq, node, ischeck) {
- var parent = jq.tree('getParent', node.target);
- if (parent) {
- if (parent.checked != ischeck) {
- if (!parent.attributes) parent.attributes = new Object();
- parent.attributes.isRecursionParent = true;
- jq.tree('update',{ target: parent.target, attributes: parent.attributes });
- if (ischeck) {
- jq.tree('check', parent.target);
- } else {
- jq.tree('uncheck', parent.target);
- }
- }
- //CMSFunction.Tree.setParentsChecked(jq, parent, ischeck);
- }
- },
- setChildrenChecked: function (jq, node, checked) {
- var childNodes = jq.tree('getChildren', node.target);
- for (var i = 0; i < childNodes.length; i++) {
- if (childNodes[i].checked != checked) {
- if (!childNodes[i].attributes) childNodes[i].attributes = new Object();
- childNodes[i].attributes.isRecursionChild = true;
- jq.tree('update',{ target: childNodes[i].target, attributes: childNodes[i].attributes });
- if (checked) jq.tree('check', childNodes[i].target);
- else jq.tree('uncheck', childNodes[i].target);
- }
- }
- },
- OnBeforeCheck: function (node, checked) {
- var treeView = $(this);
- var opts = treeView.tree('options');
-
- if (!node.attributes) node.attributes = new Object();
- if (!opts.cascadeCheck) {
- if (checked == node.checked) { return true; }
- if (checked) {
- if (!node.attributes.isRecursionChild) {
- CMSFunction.Tree.setParentsChecked(treeView, node, checked);
- }
- }
- if (!node.attributes.isRecursionParent) {
- CMSFunction.Tree.setChildrenChecked(treeView, node, checked);
- }
- node.attributes.isRecursionParent = false;
- node.attributes.isRecursionChild = false;
- treeView.tree('update',{ target: node.target, attributes: node.attributes });
- // else {
- // //opts.cascadeCheck = false;
- // var childNodes = treeView.tree('getChildren', node.target);
- // for (var i = 0; i < childNodes.length; i++) {
- // if (checked) treeView.tree('check', childNodes[i].target);
- // else treeView.tree('uncheck', childNodes[i].target);
- // }
- // }
- }
- },
- CheckBranch: function () {
- var parentid = event.srcElement.id;
- var myCheck = $(event.srcElement).attr("checked");
- $(event.srcElement).find("input[id^='" + parentid + "']").each(function () {
- if (!myCheck)
- { $(this).removeAttr("checked"); }
- else
- { $(this).attr("checked", myCheck); }
- });
- },
- OnClick: function (node) {
- var tree = $(node.target).parents('.easyui-tree');
- if (tree.tree('getChildren', node.target).length > 0) {
- tree.tree('toggle', node.target);
- }
- }
- },
- DataTable: {
- TriggerIndex: null,
- TriggerData: null,
- /// <summary>
- /// <para>本对象专门用于操作jQueryEasyUI框架的DataGrid</para>
- /// </summary>
- OnLoadSuccessFunction: function (data, callBack) {
- var target = $(this);
- var comboGrid = $(this).parents('.easyui-combogridX:first');
- if (comboGrid.length > 0) {
- CMSFunction.ComboGrid.OnLoadSuccessFunction(comboGrid, data, callBack);
- } else {
- if (callBack) {
- callBack.call(this, data);
- }
- }
- },
- CorssRowsStylerFunction: function (value, row, index) {
- if (index % 2 != 0) { //偶数行
- return 'background-color:#DAEEE1;';
- } else { //奇数行
- }
- },
- ColumnFormatterFunction: function (value, row, index, formatType, formatString, customFormatFun, overflowlength) {
- if (formatType == FormatType.None) {
- if (!value && value != 0) {
- value = "";
- }
- } else if (formatType == FormatType.DateTime) {
- if (!value && value != 0) {
- value = "";
- }
- else {
- try{
- value = value.toDateString(formatString);
- }
- catch(error){}
- }
- }
- if (overflowlength > 3) {
- value = value.toString().length <= overflowlength ? value : value.toString().substring(0, overflowlength - 3) + '...';
- }
- if (customFormatFun) {
- return customFormatFun.call(this, index, row, value);
- }
- return value;
- },
- OperaterColumnFormatterFunction: function (value, row, index, buttonArrayString) {
- var htmlString = " ";
- buttonArrayString = buttonArrayString.replace(/\^\^/g, "\"");
- var buttonArray = $.parseJSON(buttonArrayString);
- for (var i = 0; i < buttonArray.length; i++) {
- htmlString += buttonArray[i][i] + " ";
- }
- return htmlString;
- },
- LinkButtonColumnFormatterFunction: function (value, row, index, text, handleScript, formatType, formatString, overflowlength, emptyText) {
- var content = (text ? text : (!value && value != 0 ? "" : value));
- if(emptyText == undefined){
- emptyText = "";
- }
- if (content.length == 0 && emptyText.length > 0) {
- content = emptyText;
- }
- if (overflowlength > 3) {
- content = content.length < overflowlength ? content : content.substring(0, overflowlength - 3) + '...';
- }
- var html = "<a href=\"javascript:void(0);\" onclick=\"return " + handleScript + "(" + index + ",$(this).closest('.easyui-cmsXDataTable').cmsXDataTable('getRows')[" + index + "]);\" >" + content + "</a>";
- return html;
- },
- GetRowData: function (table) {
- /// <summary>
- /// <para>获取table中所有被选中的数据(最后返回的是数据是JSON格式的String类型数据)</para>
- /// <param name="table">jQuery对象,不传则默认为当前选项卡中的第一个DataGrid</param>
- /// </summary>
- var $table = null;
- if (table == undefined || table == null) {
- var $tabs = $('#index_center').tabs();
- $table = $tabs.tabs('getSelected').find("div.easyui-cmsXDataTable").eq(0);
- } else {
- $table = $(table);
- }
- if ($table == null || $table == undefined) {
- return ""
- }
- ;
- var rowsData = $table.cmsXDataTable('getSelections');
- if (rowsData.length > 0) {
- for (var i = 0; i < rowsData.length; i++) {
- var data = rowsData[i];
- data = BowinFunction.Untility.ConvertObjectDateFormat(data);
- }
- }
- // return rowsData == null ? "" : rowsData.length > 1 ? JSON.stringify(rowsData) : "[" + JSON.stringify(rowsData) + "]";
- return rowsData == null ? "" : JSON.stringify(rowsData);
- },
- GetCurrentRowData: function (obj) {
- /// <summary>
- /// <para>获取ojb对象所在行的数据(最后返回的是数据是JSON格式的String类型数据)</para>
- /// </summary>
- var rowIndex = $(obj).closest('tr').attr("xRowIndex");
- var rowDatas = $(obj).closest('.easyui-cmsXDataTable').cmsXDataTable("getRows");
- var data = BowinFunction.Untility.ConvertObjectDateFormat(rowDatas[rowIndex]);
- return "[" + JSON.stringify(data) + "]";
- }
- },
- DataTableFormatter: {
- TwoDigit: function (index, row, value) {
- if (!value || isNaN(value)) {
- if(value === 0)//判断是否为0
- {
- return value.toFixed(2).toString();
- }
- return "";
- }
- return value.toFixed(2).toString();
- }
- },
- DragDrop: {
- dragX: 0,
- dragY: 0,
- offsetX: 0,
- offsetY: 0,
- isInnerDrag: false,
- curPopupContainerItem: null,
- DropContainerItemClick: function (e) {
- var x = e.x || e.layerX || 0;
- var y = e.y || e.layerY || 0;
- var containerID = $(e.srcElement).parent().parent().attr("id");
- var menuID = containerID + "_menu";
- CMSFunction.DragDrop.curPopupContainerItem = $(e.srcElement).parent();
- $("#" + menuID).menu("show", { left: x, top: y });
- },
- DropFunc: function (e, source) {
- if (CMSFunction.DragDrop.isInnerDrag != true) {
- var newObj = $(source).clone();
- var myLeft = e.currentTarget.clientLeft;
- var myTop = e.currentTarget.clientTop;
- var myWidth = e.currentTarget.clientWidth;
- var myHeight = e.currentTarget.clientHeight;
- var myObj = e.currentTarget;
- var opts = $.data(this, "droppableContainer").options;
- newObj.css('top', CMSFunction.DragDrop.dragY - CMSFunction.DragDrop.offsetY)
- .css('position', 'absolute')
- .css('left', CMSFunction.DragDrop.dragX - CMSFunction.DragDrop.offsetX);
- newObj.find(".draggableTitle").css("color", opts.foreColor)
- newObj.appendTo($(this));
- newObj.draggable({
- handle: '.draggableTitle',
- onDrag: function (e) {
- CMSFunction.DragDrop.dragX = e.clientX;
- CMSFunction.DragDrop.dragY = e.clientY;
- },
- onBeforeDrag: function (e) {
- CMSFunction.DragDrop.offsetX = e.offsetX + e.srcElement.offsetLeft;
- CMSFunction.DragDrop.offsetY = e.offsetY + e.srcElement.offsetTop;
- CMSFunction.DragDrop.isInnerDrag = true;
- },
- onStopDrag: function (e) {
- if (e.clientX < myLeft || e.clientX > myLeft + myWidth || e.clientY < myTop || e.clientY > myTop + myHeight) {
- $(e.srcElement).offsetParent().remove();
- }
- }
- });
- }
- var hidden = $(e.currentTarget.nextSibling);
- hidden.val('');
- $.each($(e.currentTarget).find('.easyui-draggable'), function () {
- var valStr = '';
- if (hidden.val() != '') valStr = ',';
- var titleDiv = $(this).find('.draggableTitle');
- valStr += titleDiv.attr('value') + '|' + titleDiv.html() + '|' + $(this).css('left').replace("px", "") + '|' + $(this).css('top').replace("px", "");
- hidden.val(hidden.val() + valStr);
- });
- }
- }
- };
- //2013-05-31 begin added by pengbb 新增部门选择控件,由项目易系统开发提供
- var departmentSelector = function (dataUrl, multipleChoice, handlers) {
- var win;
- var tree;
- var pitchOnDataGrid;
- var rightTopQuey;
- var hasEasyUI = function (elementTypeName) {
- if ($(elementTypeName).length > 0) {
- return true;
- } else {
- return false;
- }
- }
- //private 创建Html元素
- var createElement = function (elementTypeName, elements, parentElments) {
- $(elementTypeName).removeClass();
- if (typeof parentElments != "undefined" && typeof elements == "string") {
- var elementsObject = $(elements);
- parentElments.append(elementsObject);
- return elementsObject;
- }
- else {
- if (typeof elements == "string")
- return $(elements);
- }
- };
- var createLinkButton = function (elements) {
- var links = elements.find("a");
- for (var i = 0; i < links.length; i++) {
- $(links[i]).linkbutton();
- }
- };
- var createTableString = function (name) {
- var table = "<table";
- return table.concat(" name='", name, "'>", "</table>");
- };
- var registEvent = function (target, eventType, handler) {
- target.unbind(eventType, handler);
- target.bind(eventType, handler);
- }
- //private 选择部门
- var selectWaitOrg = function (node) {
- var selectUser;
- if (multipleChoice) {
- selectUser = tree.tree('getChecked');
- } else {
- var selectUser = new Array();
- selectUser.push(node);
- }
- if (selectUser.length > 0) {
- if (!multipleChoice && selectUser.length > 1) {
- window.top.$.messager.alert("系统消息", "一次只能选择一个部门!");
- }
- else {
- var dataSource = "{\"total\":".concat(selectUser.length, ",", "\"rows\":[");
- for (var i = 0; i < selectUser.length; i++) {
- dataSource = dataSource.concat('{"OrgID":', "\"", selectUser[i].id, "\",", '"DepartmentName":',
- "\"", selectUser[i].text, "\"},"
- );
- }
- dataSource = dataSource.substring(0, dataSource.length - 1);
- dataSource = dataSource.concat("]}");
- pitchOnDataGrid.datagrid("loadData", $.parseJSON(dataSource));
- }
- } else if (multipleChoice == false) {
- window.top.$.messager.alert("系统消息", "未选择任何用户!");
- }
- };
- var InitGridFile = function (dataGrid, pagination, url) {
- return dataGrid.datagrid({
- url: pagination ? url : "",
- queryParams: pagination ? {
- departmentID: DepartmentID,
- userName: rightTopQuey.find("input[name='txtUserName']").val()
- } : "",
- pagination: pagination,
- pageSize: 1,
- pageList: [5, 10],
- loadMsg: "请稍等....",
- columns: [[
- { field: 'id', title: '', checkbox: true },
- { field: 'DepartmentName', title: '部门机构' }
- ]]
- });
- }
- var loadDepartmentTree = function () {
- var inputDepartment = leftQuery.find("input[name='txtDepartmentName']").val();
- $.cmsPost("/Common/GetSelectUserControlDepartmentTree",
- { departmentID: "", departmentName: inputDepartment },
- function (data) {
- $(tree).tree('loadData', data);
- });
- }
- var deleteSelectUser = function () {
- var deleteSource = pitchOnDataGrid.datagrid("getChecked");
- if (deleteSource.length > 0) {
- for (var i = 0; i < deleteSource.length; i++) {
- var rowIndex = pitchOnDataGrid.datagrid("getRowIndex", deleteSource[i]);
- pitchOnDataGrid.datagrid("deleteRow", rowIndex);
- if (multipleChoice) {
- var node = tree.tree("find", deleteSource[i].OrgID);
- tree.tree('uncheck', node.target);
- }
- }
- } else {
- window.top.$.messager.alert("系统消息", "未选中任何行!");
- }
- };
- var close = function () {
- var btnSelectOk = $((rightTopQuey.find("a"))[1]);
- btnSelectOk.unbind();
- btnSelectOk.bind("click", function () {
- var selectUser = pitchOnDataGrid.datagrid("getData");
- if (handlers instanceof Array) {
- for (var i = 0; i < handlers.length; i++) {
- handlers[i](selectUser);
- }
- } else if (typeof handlers != "undefined") {
- handlers(selectUser);
- }
- if (typeof (pitchOnDataGrid.data("SelectedUser")) != "undefined") {
- var catchData = pitchOnDataGrid.data("SelectedUser");
- pitchOnDataGrid.removeData("SelectedUser");
- }
- win.window("close");
- });
- };
- this.show = function () {
- if (true) {
- $("div[name='winOrgWarp']").remove();
- var warpElement = "<div class='selectOrg_warp clear' name='winOrgWarp'></div>";
- //var warp = createElement(".selectOrg_warp", warpElement, win);
- var warp = window.top.$(warpElement).appendTo(window.top.document.body);
- win = warp.window({
- width: 780,
- height: 530,
- modal: true,
- maximizable: false,
- title: '部门信息选择'
- });
- var elementLeft = createElement(".selectOrg_left",
- "<div class='selectOrg_left postion_border panel-margin'></div>", warp);
- var elementRight = createElement(".selectOrg_right",
- "<div class='selectOrg_right postion_border'></div>", warp);
- var leftQueryTable = "<table class='query'><tr>";
- leftQueryTable = leftQueryTable.concat("<td align='right'>渠道名称:</td>");
- leftQueryTable = leftQueryTable.concat("<td align='left'><input type='text' name='txtDepartmentName' class='selectUser_Input selectUser_inputCondition'/></td>");
- leftQueryTable = leftQueryTable.concat("<td colspan='2' align='center' ><a href='#' name='btnQueryDepartment'>查询</a> </td>");
- leftQueryTable = leftQueryTable.concat("</tr></table>");
- leftQuery = createElement(".query", leftQueryTable, elementLeft);
- createLinkButton(leftQuery);
- var left_panel_warp = createElement("div[panel_postion='org_left']", "<div class='panel_Data' panel_postion='org_left'><ul name='departmentTree'></ul></div>", elementLeft);
- left_panel_warp.panel({
- width: 350,
- height: 450,
- title: '部门信息',
- closable: false,
- collapsible: true,
- minimizable: false,
- maximizable: false
- });
- tree = $(left_panel_warp.find("ul[name='departmentTree']")[0]).tree({
- url: dataUrl + "?departmentName=",
- lines: true,
- checkbox: multipleChoice,
- onBeforeLoad: function (node, param) {
- if (node == null) {
- return true;
- } else {
- var children = $(this).tree("getChildren", node.target);
- if (children == "") {
- return true;
- } else {
- return false;
- }
- }
- },
- onClick: function (node) {
- selectWaitOrg(node);
- },
- onCheck: function (node) {
- selectWaitOrg();
- }
- });
- var rightQuery = '<p class="query_p right_query_Postion" pPostion="org_right_top"><a href="#" name="btnDel">删除</a>';
- rightQuery = rightQuery.concat(" <a href='#' name='btnSelectOk' >确定</a></p>");
- rightTopQuey = createElement("p[pPostion='org_right_top']", rightQuery, elementRight);
- createLinkButton(rightTopQuey);
- var left_panel_warp = createElement("div[panel_postion='right_selectOrg']", "<div class='panel_Data' panel_postion='right_selectOrg'></div>", elementRight);
- var pitchOnPanel = left_panel_warp.panel({
- width: 380,
- height: 450,
- title: '已选部门',
- closable: false,
- collapsible: true,
- minimizable: false,
- maximizable: false
- });
- var pitchOnTable = createElement("table[name='pitchOnOrgDataGrid']", createTableString("pitchOnOrgDataGrid"), pitchOnPanel);
- pitchOnDataGrid = (InitGridFile(pitchOnTable, false));
- //查询部门树
- registEvent(leftQuery.find("a:first"), "click", loadDepartmentTree);
- //删除
- registEvent($(rightTopQuey.find("a")[0]), "click", deleteSelectUser);
- //确认
- close(handlers);
- } else {
- $("div[name='winOrgWarp']").window('open');
- }
- }
- };
- //2013-05-31 end added by pengbb 新增部门选择控件,由项目易系统开发提供
- //
- var brandSelector = function (dataUrl, multipleChoice, triggerboxTarget, handlers) {
- var win;
- var tree;
- var pitchOnDataGrid;
- var rightTopQuey;
- var hasEasyUI = function (elementTypeName) {
- if ($(elementTypeName).length > 0) {
- return true;
- } else {
- return false;
- }
- }
- //private 创建Html元素
- var createElement = function (elementTypeName, elements, parentElments) {
- $(elementTypeName).removeClass();
- if (typeof parentElments != "undefined" && typeof elements == "string") {
- var elementsObject = $(elements);
- parentElments.append(elementsObject);
- return elementsObject;
- }
- else {
- if (typeof elements == "string")
- return $(elements);
- }
- };
- var createLinkButton = function (elements) {
- var links = elements.find("a");
- for (var i = 0; i < links.length; i++) {
- $(links[i]).linkbutton();
- }
- };
- var createTableString = function (name) {
- var table = "<table";
- return table.concat(" name='", name, "'>", "</table>");
- };
- var registEvent = function (target, eventType, handler) {
- target.unbind(eventType, handler);
- target.bind(eventType, handler);
- }
- //private 选择品牌
- var selectWaitOrg = function (node) {
- var selectUser;
- if (multipleChoice) {
- selectUser = tree.tree('getChecked');
- } else {
- var selectUser = new Array();
- selectUser.push(node);
- }
- var removeArray = new Array();
- for (var i = 0; i < selectUser.length; i++) {
- if (!selectUser[i].attributes.parentDepartmentID) {//查找根节点
- removeArray.push(selectUser[i]);
- }
- else {
- for (var x = 0; x < selectUser.length; x++) {
- if (selectUser[i].attributes.parentDepartmentID == selectUser[x].id) {//查找父节点
- removeArray.push(selectUser[x]);
- }
- }
- }
- }
- for (var i = 0; i < removeArray.length; i++) { //移除选中项
- for (var x = 0; x < selectUser.length; x++) {
- if (removeArray[i].id == selectUser[x].id) {
- selectUser.splice(x, 1);
- break;
- }
- }
- }
- $(tree).data("Selections", selectUser);
- };
- this.show = function () {
- if (true) {
- $("div[name='winOrgWarp']").remove();
- var warpElement = "<div class='selectOrg_warp clear' name='winOrgWarp'></div>";
- var warp = window.top.$(warpElement).appendTo(window.top.document.body);
- var elementLeft = createElement(".selectOrg_left",
- "<div class='postion_border panel-margin'></div>", warp);
- var elementRight = createElement(".selectOrg_right",
- "<div class='selectOrg_right postion_border'></div>", warp);
- var left_panel_warp = createElement("div[panel_postion='org_left']", "<div class='panel_Data' panel_postion='org_left'><ul name='departmentTree'></ul></div>", elementLeft);
- tree = $(left_panel_warp.find("ul[name='departmentTree']")[0]).tree({
- url: dataUrl + "?departmentName=",
- lines: true,
- checkbox: multipleChoice,
- onBeforeLoad: function (node, param) {
- if (node == null) {
- return true;
- } else {
- var children = $(this).tree("getChildren", node.target);
- if (children == "") {
- return true;
- } else {
- return false;
- }
- }
- },
- onLoadSuccess: function (node, data) {
- var checkedData = $(triggerboxTarget).triggerbox("getValue");
- if (checkedData != "") {
- var checkedArray = checkedData.split(';');
- for (var i = 0; i < checkedArray.length; i++) {
- var checkedNode = tree.tree("find", checkedArray[i]);
- tree.tree("check", checkedNode.target);
- }
- }
- },
- onClick: function (node) {
- selectWaitOrg(node);
- },
- onCheck: function (node) {
- selectWaitOrg();
- }
- });
- win = warp.dialog({
- width: 400,
- height: 600,
- modal: true,
- maximizable: false,
- title: '品牌信息选择',
- buttons:
- [{
- text: '确定',
- handler: function () {
- var result = $(tree).data("Selections") || new Array();
- if (handlers instanceof Array) {
- for (var i = 0; i < result.length; i++) {
- handlers[i](result);
- }
- } else if (typeof handlers != "undefined") {
- handlers(result);
- }
- warp.dialog("close");
- }
- },
- {
- text: '取消',
- handler: function () {
- warp.dialog("close");
- }
- }]
- });
- } else {
- $("div[name='winOrgWarp']").dialog('open');
- }
- }
- };
- var brandSelectorHandlers = function (targe, node) {
- var datas = [];
- $.each(node, function () {
- datas.push([{ 'text': this.text, 'value': this.id }][0]);
- });
- $(targe).triggerbox('setValue', datas);
- };
- //
- //2013-05-29 begin added by pengbb 新增系统菜单控件
- /*用法:定义一个div,指定class 为 easyui-cmsTree
- <div class="easyui-cmsTree" data-options="url:'/Common/GetCurrentUserMenuList'" >
- </div>
- data-options参数如下:
- url:'/Common/GetCurrentUserMenuList'
- onMenuClick:function(node){}
- */
- (function ($) {
- $.parser.plugins.push("cmsTree");
- function _toggleChildMenu(currMenu) {
- //$(currMenu).next('div').toggle();
- if ($(currMenu).next('div').css("display") == "none") {
- $(currMenu).siblings("div").slideUp("normal");
- $(currMenu).next('div').slideDown("normal");
- } else {
- $(currMenu).next('div').slideUp("normal");
- }
- }
- function _hideAllChildMenu(jq) {
- $(jq).find('a+div').hide();
- }
- function _init(jq) {
- var opts = $.data(jq, "cmsTree").options;
- $(jq).addClass("menu_panel");
- //$(jq).height(opts.height);
- var defaultOpenMenu = null;
- var newUrl = opts.url;
- if (opts.loadingMessage) {
- $(jq).html($("<div class=\"panel-loading\"></div>").html(opts.loadingMessage));
- }
- $.post(newUrl, {}, function (responseJson) {
- var rootPanel = jq;
- var i = 0;
- $.each(responseJson, function () {
- var level1Menu = $("<a class=\"menu_item menu_item_level1\" href=\"javascript:void(0);\" click=\"return false;\" title=\"系统首页\"><span style=\"background-position: 0px 0px;background-repeat: no-repeat;\">系统首页</span> </a>");
- var level1MenuOption = this;
- level1Menu.appendTo(rootPanel);
- level1Menu.find("span").text(level1MenuOption.text);
- level1Menu.find("span").addClass("menu_item_level1_title");
- if (level1MenuOption.text != "系统首页" && level1MenuOption.text != "系统注销" && i == 0) {
- i = 1;
- defaultOpenMenu = level1Menu;
- }
- if (level1MenuOption.iconUrl) {
- level1MenuOption.iconUrl = "url(" + level1MenuOption.iconUrl + ")";
- level1Menu.find(">span").css({ backgroundPosition: "10px 6px", backgroundImage: level1MenuOption.iconUrl });
- }
- level1Menu.attr("title", level1MenuOption.text);
- level1Menu.data("menuOption", level1MenuOption);
- if (level1MenuOption.children.length > 0) {
- var level2Panel = $("<div class=\"menu_item_panel\"></div>").appendTo(rootPanel);
- $.each(level1MenuOption.children, function () {
- var level2Menu = $("<a class=\"menu_item menu_item_level2\" href=\"javascript:void(0);\" click=\"return false;\" title=\"系统首页\"><span >系统首页</span> </a>");
- var level2MenuOption = this;
- level2Menu.appendTo(level2Panel);
- level2Menu.find("span").text(level2MenuOption.text);
- level2Menu.find("span").addClass("menu_item_level2_title");
- level2Menu.attr("title", level2MenuOption.text);
- level2Menu.data("menuOption", level2MenuOption);
- if (level2MenuOption.children.length > 0) {
- //menu_item_level2_icon_opened
- //menu_item_level2_icon_closed
- level2Menu.addClass("menu_item_collapsable")
- .find("span").css({ paddingLeft: "20px" }).addClass("menu_item_level2_icon_closed");
- var levelLeafPanel = $("<div class=\"menu_item_leaf_panel\"></div>").appendTo(level2Panel);
- $.each(level2MenuOption.children, function () {
- var levelLeafMenu = $("<a class=\"menu_item menu_item_leaf\" href=\"javascript:void(0);\" click=\"return false;\" title=\"系统首页\"><span style=\"background-position: 0px 0px;background-repeat: no-repeat;background-size: 16px 12px;\">系统首页</span> </a>");
- var levelLeafMenuOption = this;
- levelLeafMenu.appendTo(levelLeafPanel);
- levelLeafMenu.find("span").text(levelLeafMenuOption.text);
- levelLeafMenu.find("span").addClass("menu_item_leaf_title");
- levelLeafMenu.find("span").addClass("menu_item_leaf_icon");
- levelLeafMenu.find("span").css({ backgroundImage: levelLeafMenuOption.iconUrl });
- levelLeafMenu.attr("title", levelLeafMenuOption.text);
- levelLeafMenu.data("menuOption", levelLeafMenuOption);
- });
- }
- });
- }
- _hideAllChildMenu(jq);
- });
- if (defaultOpenMenu) {
- _toggleChildMenu(defaultOpenMenu);
- }
- // $(rootPanel).find("div.menu_item_panel").tinyscrollbar();
- }, "json");
- return { cmsTree: jq };
- }
- $.fn.cmsTree = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsTree.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsTree(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var _jqThis = $(_this);
- var cacheData = $.data(_this, "cmsTree");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsTree", { options: $.extend({}, $.fn.cmsTree.defaults, $.fn.cmsTree.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- initCacheData.clickCallbacks = $.Callbacks();
- cacheData = $.data(_this, "cmsTree", $.extend({}, cacheData, initCacheData));
- _jqThis.find("a.menu_item").live("click", function (event) {
- //alert($(this).attr("title"));
- //alert(JSON.stringify($(this).data("menuOption")));
- //menu_item_level2_icon_opened
- //menu_item_level2_icon_closed
- if ($(this).hasClass("menu_item_collapsable")) {
- var span = $(this).find(">span");
- if (span.hasClass("menu_item_level2_icon_closed")) {
- span.removeClass("menu_item_level2_icon_closed");
- span.addClass("menu_item_level2_icon_opened");
- } else {
- span.removeClass("menu_item_level2_icon_opened");
- span.addClass("menu_item_level2_icon_closed");
- }
- $(this).siblings(".menu_item_collapsable").find(">span").removeClass("menu_item_level2_icon_opened").addClass("menu_item_level2_icon_closed");
- }
- var opts = _jqThis.data("cmsTree").options;
- _toggleChildMenu(this);
- var menuOption = $(this).data("menuOption");
- if (opts.onMenuClick) {
- opts.onMenuClick.call(_this, menuOption);
- }
- return false;
- });
- //_jqThis.find("div.menu_item_panel").tinyscrollbar({ axis: 'x', size: 20});
- }
- });
- };
- $.fn.cmsTree.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsTree").options;
- return opts;
- }
- };
- $.fn.cmsTree.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsTree.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsTree.defaults = {
- url: '',
- loadingMessage: '菜单正在加载中...',
- onMenuClick: function () { } //,
- //height: 700
- };
- })(jQuery);
- //2013-05-29 end added by pengbb 新增系统菜单控件
- //2013-05-21 begin added by pengbb 附件上传控件
- /*用法:定义一个div,指定class 为 easyui-AttachmentUploader
- <div class="easyui-AttachmentUploader" style="width:auto;height:200px;" data-options="formData:{ReferenceID:'999F598B-541E-4863-8354-D54F8D47AFDD',ReferenceKeyName:'CMS_ApplicationBill'}">
- </div>
- data-options参数如下:
- title: "附件列表",
- canUpload: true, //是否可以上传
- formData: {
- ReferenceID: '',
- ReferenceKeyName: 'CMS'
- },
- multi: true, //是否启用批量上传
- fileSizeLimit: 0, // The maximum size of an uploadable file in KB (Accepts units B KB MB GB if string, 0 for no limit)
- fileTypeDesc : 'Image Files', // The description for file types in the browse dialog
- fileTypeExts : '*.gif; *.jpg; *.png', // Allowed extensions in the browse dialog (server-side validation should also be used)
- buttonText: '上传附件',
- buttonClass: '',
- swf: '/Scripts/Plugins/Uploadify/uploadify.swf',
- uploader: '/UploadFile.axd',
- uploadSuccess: function (file, data, response) { },
- uploadFailure: function (file, data, response) { }
- */
- (function ($) {
- $.parser.plugins.push("AttachmentUploader");
- function s4() {
- return Math.floor((1 + Math.random()) * 0x10000)
- .toString(16)
- .substring(1);
- }
- function guid() {
- return s4() + s4() + '-' + s4() + '-' + s4() + '-' +
- s4() + '-' + s4() + s4() + s4();
- }
- function _init(jq) {
- var opts = $.data(jq, "AttachmentUploader").options;
- var plAttachment = jq;
- var jqThis = $(jq);
- var dgAttachment = jqThis.find("div.upload_filelist>div");
- var btnUpload = jqThis.find("div.upload_tool>input");
- dgAttachment.cmsXDataTable();
- return { AttachmentUploader: jq, btnUpload: btnUpload, dgAttachment: dgAttachment };
- }
- function _deleteAttachment(jq, id) {
- var dgAttachment = $.data(jq, "AttachmentUploader").dgAttachment;
- $.messager.confirm('系统提示', '确定要删除该附件吗?', function (r) {
- if (r) {
- var ops = {
- URL: ("/" + CMS_SystemConfig.VirtualDirectoryPath + '/Common/RemoveAttachment/').replaceDoubleSlashesToSingle() + id,
- Before: function (rows) {
- },
- CallBack: function (result) {
- $.messager.alert('系统提示', '删除成功!', 'info', function () {
- setTimeout(function () { dgAttachment.cmsXDataTable('load') }, 100);
- });
- }
- }
- BowinFunction.Request.AJAX(ops);
- }
- })
- }
- $.fn.AttachmentUploader = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.AttachmentUploader.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.AttachmentUploader(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "AttachmentUploader");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "AttachmentUploader", { options: $.extend({}, $.fn.AttachmentUploader.defaults, $.fn.AttachmentUploader.parseOptions(this), _7be) });
- cacheData.options = $.extend({}, cacheData.options, {
- onUploadSuccess: function (file, data, response) {
- setTimeout(function () { dgAttachment.cmsXDataTable("load"); }, 100);
- if (opts.uploadSuccess) {
- opts.uploadSuccess.call(this, file, data, response);
- }
- },
- onAllComplete: function (event, data) {
- opts.onAllComplete.call(this, event, data);
- },
- onUploadError: function (file, data, response) {
- if (opts.uploadFailure) {
- opts.uploadFailure.call(this, file, data, response);
- }
- }
- });
- var initCacheData = _init(this);
- cacheData = $.data(this, "AttachmentUploader", $.extend({}, cacheData, initCacheData));
- }
- var opts = cacheData.options;
- var btnUpload = cacheData.btnUpload;
- var dgAttachment = cacheData.dgAttachment;
- if (opts.canUpload) {
- btnUpload.show();
- try {
- btnUpload.uploadify("destroy");
- } catch (ignore) { }
- btnUpload.uploadify(opts);
- } else {
- btnUpload.hide();
- }
- });
- };
- $.fn.AttachmentUploader.deleteColumnFormatFun = function (index, row, value) {
- if (row["IsOwn"]) {
- return "<a title=\"删除\" href=\"javascript:void(0);\" onclick=\"$(this).closest('div.easyui-AttachmentUploader').AttachmentUploader('deleteAttachment','" + value + "'); return false;\" >删除</a>";
- } else {
- return "<lable> </lable>";
- }
- };
- $.fn.AttachmentUploader.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "AttachmentUploader").options;
- return opts;
- },
- getDatagrid: function (jq) {
- var dgAttachment = $.data(jq[0], "AttachmentUploader").dgAttachment;
- return dgAttachment;
- },
- deleteAttachment: function (jq, id) {
- return _deleteAttachment(jq[0], id);
- },
- destroy: function (jq) {
- var btnUpload = $.data(jq[0], "AttachmentUploader").btnUpload;
- btnUpload.uploadify("destroy");
- }
- };
- $.fn.AttachmentUploader.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.AttachmentUploader.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.AttachmentUploader.defaults = {
- title: "附件列表",
- canUpload: true,
- formData: {
- ReferenceID: '',
- ReferenceKeyName: 'CMS'
- },
- width: 70, // The width of the browse button
- height: 26, // The height of the browse button
- createUserID: "",
- canDelete: true,
- multi: true,
- fileSizeLimit: 0, // The maximum size of an uploadable file in KB (Accepts units B KB MB GB if string, 0 for no limit)
- fileTypeDesc: '所有文件', // The description for file types in the browse dialog
- fileTypeExts: '*.*', // Allowed extensions in the browse dialog (server-side validation should also be used)
- buttonText: '上传附件',
- buttonClass: '',
- swf: ('/' + CMS_SystemConfig.VirtualDirectoryPath + '/Scripts/Plugins/Uploadify/uploadify.swf').replaceDoubleSlashesToSingle(),
- uploader: ('/' + CMS_SystemConfig.VirtualDirectoryPath + '/UploadFile.axd').replaceDoubleSlashesToSingle(),
- uploadSuccess: function (file, data, response) {
- },
- uploadFailure: function (file, data, response) { },
- onAllComplete: function (event, data) {
- //$('.easyui-window').window('close');
- }
- };
- })(jQuery);
- //2013-05-21 end added by pengbb 附件上传控件
- //2013-08-01 begin added by pengbb 新增弹窗上传控件
- (function ($) {
- $.parser.plugins.push("FileUploaderWindow");
- function s4() {
- return Math.floor((1 + Math.random()) * 0x10000)
- .toString(16)
- .substring(1);
- }
- function guid() {
- return s4() + s4() + '-' + s4() + '-' + s4() + '-' +
- s4() + '-' + s4() + s4() + s4();
- }
- function _init(jq) {
- var opts = $.data(jq, "FileUploaderWindow").options;
- var plAttachment = jq;
- var jqThis = $(jq);
- var win = jqThis.find(".FileUploaderWindowPanel");
- var fileUploader = win.find(".easyui-AttachmentUploader");
- //win.window();
- return { FileUploaderWindow: jq, FileUploader: fileUploader, Window: win };
- }
- $.fn.FileUploaderWindow = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.FileUploaderWindow.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.FileUploaderWindow(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "FileUploaderWindow");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "FileUploaderWindow", { options: $.extend({}, $.fn.FileUploaderWindow.defaults, $.fn.FileUploaderWindow.parseOptions(this), _7be) });
- var initCacheData = _init(this);
- cacheData = $.data(this, "FileUploaderWindow", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.FileUploaderWindow.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "FileUploaderWindow").options;
- return opts;
- },
- open: function (jq) {
- var data = $.data(jq[0], "FileUploaderWindow");
- var opts = data.options;
- var win = data.Window;
- var fileUploader = data.FileUploader;
- fileUploader.AttachmentUploader(opts);
- win.window().show().window("open");
- },
- close: function (jq) {
- var data = $.data(jq[0], "FileUploaderWindow");
- var opts = data.options;
- var win = data.Window;
- var fileUploader = data.FileUploader;
- fileUploader.AttachmentUploader("destroy");
- win.window("close");
- }
- };
- $.fn.FileUploaderWindow.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.FileUploaderWindow.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.FileUploaderWindow.defaults = $.extend({}, $.fn.AttachmentUploader.defaults, {
- formData: {
- ReferenceID: '',
- ReferenceKeyName: 'TempFile'
- }
- });
- })(jQuery);
- //2013-08-01 end added by pengbb 新增弹窗上传控件
- //2013-04-28 begin added by pengbb 新增triggerbox控件,用于用户选择和部门选择,号码规则选择
- (function ($) {
- $.parser.plugins.push("triggerbox");
- function _init(jq) {
- var widthCss = $(jq).width();
- $(jq).addClass("triggerbox-f").hide();
- var span = $("<span class=\"triggerbox\"></span>").insertAfter(jq);
- var span_text = $("<input type=\"text\" readonly=\"true\" style=\"width:100%;\" class=\"triggerbox-text\">").appendTo(span);
- var span_delete = $("<span><span class=\"triggerbox-delete\"></span></span>").appendTo(span);
- var span_search = $("<span><span class=\"triggerbox-search\"></span></span>").appendTo(span);
- $("<input type=\"hidden\" class=\"triggerbox-value\">").appendTo(span);
- var name = $(jq).attr("name");
- if (name) {
- span.find("input.triggerbox-value").attr("name", name);
- $(jq).removeAttr("name").attr("triggerboxName", name);
- }
- span_text.attr("autocomplete", "off");
- //span.css("width", widthCss);
- span_text.width(widthCss - span_search.width() - span_delete.width() - 10);
- //span_text.width(span.width() - span_search.width() - span_delete.width());
- return { triggerbox: span };
- }
- function _setValue(jq, newData, isValidate) {
- var opts = $.data(jq, "triggerbox").options;
- var data = $.data(jq, "triggerbox").data;
- var span = $.data(jq, "triggerbox").triggerbox;
- data = newData;
- var ss = [];
- for (var i = 0; i < newData.length; i++) {
- var s = newData[i][opts.valueField];
- if (opts.formatter) {
- s = opts.formatter.call(jq, newData[i]);
- }
- ss.push(s);
- }
- var oldTriggerboxValue = span.find("input.triggerbox-value").val();
- span.find("input.triggerbox-text").val(ss.join(opts.separator));
- span.find("input.triggerbox-value").val(JSON.stringify(newData));
- var reg = "/" + opts.separator + "/g";
- span.find("input.triggerbox-text").attr("title", ss.join(opts.separator).replace(eval(reg), "\r\n"));
- if (opts.required && isValidate) {
- //try{
- var _769 = span.find("input.triggerbox-text");
- _769.validatebox("validate");
- // }catch(ignore){}
- }
- // if (ss.join(opts.separator).length > 0 && vv.join(opts.separator).length > 0) {
- // span.find(".triggerbox-delete").css("visibility", "visible");
- // } else {
- // span.find(".triggerbox-delete").css("visibility", "hidden");
- // }
- $.data(jq, "triggerbox", { options: opts, data: data, triggerbox: span });
- if (oldTriggerboxValue != span.find("input.triggerbox-value").val()) {
- var changeFn = opts.change || function () { };
- if (typeof (changeFn) == "function") {
- changeFn.call(jq);
- }
- }
- }
- function _initValidate(_768, doit) {
- var opts = $.data(_768, "triggerbox").options;
- var _769 = $.data(_768, "triggerbox").triggerbox.find("input.triggerbox-text");
- _769.validatebox(opts);
- $(_768).removeClass("easyui-validatebox validatebox-text");
- if (doit) {
- _769.validatebox("validate");
- }
- };
- $.fn.triggerbox = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.triggerbox.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.triggerbox(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var triggerboxData = $.data(this, "triggerbox");
- if (triggerboxData) {
- $.extend(triggerboxData.options, _7be);
- } else {
- triggerboxData = $.data(this, "triggerbox", { options: $.extend({}, $.fn.triggerbox.defaults, $.fn.triggerbox.parseOptions(this), _7be) });
- var initTriggerboxData = _init(this);
- triggerboxData = $.data(this, "triggerbox", $.extend({}, triggerboxData, initTriggerboxData));
- }
- if (triggerboxData.options.data) {
- _setValue(this, triggerboxData.options.data, false);
- }
- triggerboxData.triggerbox.find(".triggerbox-search").unbind(".triggerbox");
- triggerboxData.triggerbox.find(".triggerbox-delete").unbind(".triggerbox");
- //注册事件
- triggerboxData.triggerbox.find(".triggerbox-search").bind("mouseenter.triggerbox", function () {
- $(this).addClass("triggerbox-search-hover");
- }).bind("mouseleave.triggerbox", function () {
- $(this).removeClass("triggerbox-search-hover");
- }).bind("mousedown.triggerbox", function () {
- if (triggerboxData.options.editable) {
- //查询点击事件
- if (triggerboxData.options.onSearch) {
- triggerboxData.options.onSearch.call(_this);
- }
- }
- });
- triggerboxData.triggerbox.find(".triggerbox-search").bind("mouseenter.triggerbox", function () {
- $(this).addClass("triggerbox-search-hover");
- }).bind("mouseleave.triggerbox", function () {
- $(this).removeClass("triggerbox-search-hover");
- }).bind("mousedown.triggerbox", function () {
- if (triggerboxData.options.editable) {
- //查询点击事件
- if (triggerboxData.options.onSearchClick) {
- triggerboxData.options.onSearchClick.call(_this);
- }
- }
- });
- triggerboxData.triggerbox.find(".triggerbox-delete").bind("mouseenter.triggerbox", function () {
- $(this).addClass("triggerbox-delete-hover");
- }).bind("mouseleave.triggerbox", function () {
- $(this).removeClass("triggerbox-delete-hover");
- }).bind("mousedown.triggerbox", function () {
- if (triggerboxData.options.editable) {
- $.fn.triggerbox.methods["clear"]($(_this));
- //$(this).css("visibility", "hidden");
- }
- });
- _initValidate(_this, true);
- });
- };
- $.fn.triggerbox.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "triggerbox").options;
- return opts;
- },
- getData: function (jq) {
- return $.data(jq[0], "triggerbox").data;
- },
- setValue: function (jq, newData) {
- jq.each(function () {
- _setValue(this, newData, true);
- });
- },
- getValue: function (jq) {
- return eval($.data(jq[0], "triggerbox").triggerbox.find("input.triggerbox-value").val());
- },
- clear: function (jq) {
- jq.each(function () {
- var opts = $(this).triggerbox("options");
- opts.data = [];
- $(this).triggerbox("setValue", opts.data);
- });
- }
- };
- $.fn.triggerbox.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.extend({}, $.fn.triggerbox.defaults, $.parser.parseOptions(_7c7, ["valueField", "textField"])), $.fn.validatebox.parseOptions(_7c7));
- };
- $.fn.triggerbox.defaults = $.extend({},
- $.fn.validatebox.defaults, {
- valueField: "value",
- textField: "text",
- separator: ",",
- editable: true,
- postData: {},
- change: function () { },
- formatter: function (row) {
- var opts = $(this).triggerbox("options");
- return row[opts.textField];
- }
- }
- );
- })(jQuery);
- //2013-04-28 end added by pengbb 新增triggerbox控件,用于用户选择和部门选择,号码规则选择
- //2013-05-03 begin added by pengbb 新增号码规则选择控件
- function TelNumberRuleSelector(config) {
- var defaultConfig = { onSelect: null, width: 600, height: 400, postData: {} };
- config = $.extend({}, defaultConfig, config);
- var newUrl = "/Common/GetTelNumberRuleListForSelector";
- newUrl = ("/" + CMS_SystemConfig.VirtualDirectoryPath + newUrl).replaceDoubleSlashesToSingle();
- var jqPanel = $("<div class=\"easyui-window\" style=\"width:800px;height:600px; \" title=\"选择号码规则\" data-options=\"modal:true,collapsible:false,shadow:true,minimizable:false,maximizable:false,inline:false,closed:true,resizable:false,maximizable:false \" ></div> ").appendTo(document.body);
- var jqPanelLayout = $('<div style="width:100%;height:100%;" class="layout" ><div style="left: 0px; top: 0px; width:100%; " class="panel layout-panel layout-panel-center"><div class="panel-body panel-body-noheader panel-body-noborder layout-body" title="" style="position: relative; width:100%; height: 320px; overflow: auto;"></div></div><div style="left: 0px; top: 320px; width: 100%;" class="panel layout-panel layout-panel-south"><div class="panel-body panel-body-noheader panel-body-noborder layout-body" title="" style="height: 29px; text-align: right; padding: 5px 0px 0px; width: 100%;"><!-- 窗口操作按扭 --></div></div> </div>').appendTo(jqPanel);
- var jqPanelLayoutCenter = jqPanelLayout.find("div.layout-panel-center>div.layout-body");
- var jqPanelLayoutCenterContent = $('<div style="padding:5px;" ></div>').appendTo(jqPanelLayoutCenter);
- var jqPanelLayoutSouth = jqPanelLayout.find("div.layout-panel-south>div.layout-body");
- var btnYes = $("<a class=\"easyui-linkbutton\" data-options=\"iconCls:'icon-ok'\" style=\"margin-right:5px;\" href=\"javascript:void(0)\" >确定</a>").appendTo(jqPanelLayoutSouth);
- var btnNo = $("<a class=\"easyui-linkbutton\" data-options=\"iconCls:'icon-cancel'\" style=\"margin-right:5px;\" href=\"javascript:void(0)\" >取消</a>").appendTo(jqPanelLayoutSouth);
- if (config.width) {
- jqPanel.width(config.width);
- }
- if (config.height) {
- jqPanel.height(config.height);
- }
- jqPanel.window();
- btnYes.linkbutton();
- btnNo.linkbutton();
- var isIE6 = false;
- if ($.browser.msie) {
- if ($.browser.version < 7) {
- isIE6 = true;
- }
- }
- var centerContentConfig = {
- url: newUrl,
- postData: config.postData,
- onLoaded: function () {
- jqPanelLayoutCenterContent.find("div.cmspanel>div.panel-header>div.panel-tool>a.cmspanel-tool-collapse").click(function () {
- var _this = $(this);
- if (_this.hasClass("panel-tool-expand")) {
- _this.removeClass("panel-tool-expand");
- if (isIE6) {
- _this.closest("div.cmspanel").find("div.panel-body").show();
- } else {
- _this.closest("div.cmspanel").find("div.panel-body").slideDown();
- }
- } else {
- _this.addClass("panel-tool-expand");
- if (isIE6) {
- _this.closest("div.cmspanel").find("div.panel-body").hide();
- } else {
- _this.closest("div.cmspanel").find("div.panel-body").slideUp();
- }
- }
- });
- }
- };
- jqPanelLayoutCenterContent.cmsLoadHtml(centerContentConfig);
- var eventManager = { onSelect: [] };
- var _select = function (fn) {
- eventManager["onSelect"].push(fn);
- }
- if (config.onSelect) {
- eventManager["onSelect"].push(config.onSelect);
- }
- btnYes.unbind(".SelectTelNumberRule");
- btnNo.unbind(".SelectTelNumberRule");
- btnYes.bind("click.SelectTelNumberRule", function () {
- var selectDatas = [];
- $(jqPanel).find("input[type=checkbox]:checked").each(function () {
- selectDatas.push({ text: $(this).attr("text"), value: $(this).val() });
- });
- _postEvent(selectDatas);
- _hide();
- });
- btnNo.bind("click.SelectTelNumberRule", function () {
- _hide();
- });
- var _show = function () {
- jqPanel.window('open');
- };
- var _hide = function () {
- jqPanel.window('close');
- };
- var _postEvent = function (p) {
- $.each(eventManager["onSelect"], function () {
- this.call(_this, p);
- });
- }
- var _this = { jq: jqPanel, show: _show, hide: _hide, select: _select };
- return _this;
- }
- //2013-05-03 end added by pengbb新增号码规则选择控件
- var SelectUserContorl = function (departmentID, multipleChoice, handlers) {
- var groups = {};
- var DepartmentID = departmentID;
- var MultipleChoice = multipleChoice;
- var waitDataGrid;
- var pitchOnDataGrid;
- var rightTopQuey;
- var tree;
- var win;
- var leftQuery;
- //private 创建Html元素
- var createElement = function (elementTypeName, elements, parentElments) {
- $(elementTypeName).removeClass();
- if (typeof parentElments != "undefined" && typeof elements == "string") {
- var elementsObject = $(elements);
- parentElments.append(elementsObject);
- return elementsObject;
- } else {
- if (typeof elements == "string")
- return $(elements);
- }
- };
- var createTableString = function (name) {
- var table = "<table";
- return table.concat(" name='", name, "'>", "</table>");
- };
- var InitGridFile = function (dataGrid, pagination, url) {
- return dataGrid.datagrid({
- url: pagination ? url : "",
- queryParams: pagination ? {
- departmentID: DepartmentID,
- userName: rightTopQuey.find("input[name='txtUserName']").val()
- } : "",
- pagination: pagination,
- pageSize: 1,
- pageList: [5, 10],
- loadMsg: "请稍等....",
- columns: [[
- { field: 'UserID', title: 'UserID', checkbox: true },
- { field: 'DepartmentName', title: '部门机构' },
- { field: 'LoginName', title: '登录名' },
- { field: 'UserName', title: '用户名' }
- ]]
- });
- }
- //private 选择用户
- var selectWaitUser = function () {
- var selectUser = waitDataGrid.datagrid("getChecked");
- if (selectUser.length > 0) {
- if (!multipleChoice && selectUser.length > 1) {
- $.messager.alert("系统消息", "一次只能选择一个用户!");
- } else {
- var dataSource = "{\"total\":".concat(selectUser.length, ",", "\"rows\":[");
- for (var i = 0; i < selectUser.length; i++) {
- dataSource = dataSource.concat('{"UserID":', "\"", selectUser[i].UserID, "\",", '"DepartmentName":',
- "\"", selectUser[i].DepartmentName, "\",\"LoginID\":\"", selectUser[i].LoginName, "\",\"UserName\":\"",
- selectUser[i].UserName, "\"},"
- );
- }
- dataSource = dataSource.substring(0, dataSource.length - 1);
- dataSource = dataSource.concat("]}");
- var currentData = $.parseJSON(dataSource);
- currentData.rows = currentData.rows.sort(function (a, b) {
- return a > b;
- });
- if (typeof (pitchOnDataGrid.data("SelectedUser")) != "undefined") {
- //先拿缓存数据
- var cachData = pitchOnDataGrid.data("SelectedUser");
- for (var i = 0; i < cachData.rows.length; i++) {
- for (var j = 0; j < currentData.rows.length; j++) {
- if (cachData.rows[i].UserID == currentData.rows[j].UserID) {
- currentData.rows.splice(j, 1);
- }
- }
- }
- cachData.rows = $.merge(currentData.rows, cachData.rows);
- pitchOnDataGrid.data("SelectedUser", cachData);
- } else {
- pitchOnDataGrid.data("SelectedUser", currentData);
- }
- pitchOnDataGrid.datagrid("loadData", pitchOnDataGrid.data("SelectedUser"));
- }
- } else {
- $.messager.alert("系统消息", "未选择任何用户!");
- }
- };
- var registEvent = function (target, eventType, handler) {
- target.unbind(eventType, handler);
- target.bind(eventType, handler);
- }
- var close = function () {
- var btnSelectOk = $((rightTopQuey.find("a"))[1]);
- btnSelectOk.unbind();
- btnSelectOk.bind("click", function () {
- var selectUser = pitchOnDataGrid.datagrid("getData");
- if (handlers instanceof Array) {
- for (var i = 0; i < handlers.length; i++) {
- handlers[i](selectUser);
- }
- } else if (typeof handlers != "undefined") {
- handlers(selectUser);
- }
- win.window("close");
- });
- };
- var hasEasyUI = function (elementTypeName) {
- if ($(elementTypeName).length > 0) {
- return true;
- } else {
- return false;
- }
- }
- var createLinkButton = function (elements) {
- var links = elements.find("a");
- for (var i = 0; i < links.length; i++) {
- $(links[i]).linkbutton();
- }
- };
- var getUserInfo = function () {
- waitDataGrid.datagrid('load', {
- departmentID: DepartmentID,
- userName: rightTopQuey.find("input[name='txtUserName']").val()
- }
- );
- }
- var deleteSelectUser = function () {
- var deleteSource = pitchOnDataGrid.datagrid("getChecked");
- if (deleteSource.length > 0) {
- for (var i = 0; i < deleteSource.length; i++) {
- var rowIndex = pitchOnDataGrid.datagrid("getRowIndex", deleteSource[i]);
- pitchOnDataGrid.datagrid("deleteRow", rowIndex);
- }
- }
- //else {
- // $.messager.alert("系统消息", "未选中任何行!");
- // }
- };
- var loadDepartmentTree = function () {
- var inputDepartment = leftQuery.find("input[name='txtDepartmentName']").val();
- $.cmsPost("/Common/GetSelectUserControlDepartmentTree",
- { departmentID: "", departmentName: inputDepartment },
- function (data) {
- $(tree).tree('loadData', data);
- });
- }
- var show = function () {
- if (!hasEasyUI("div[name='winWarp']")) {
- var warpElement = "<div class='selectUser_warp clear'></div>";
- var warp = createElement(".selectUser_warp", warpElement, win);
- win = warp.window({
- width: 760,
- height: 500,
- modal: true,
- maximizable: false,
- title: '用户信息选择'
- });
- var elementLeft = createElement(".selectUser_left",
- "<div class='selectUser_left postion_border'></div>", warp);
- var elementRight = createElement(".selectUser_right",
- "<div class='selectUser_right postion_border'></div>", warp);
- var leftQueryTable = "<table class='query'><tr>";
- leftQueryTable = leftQueryTable.concat("<td align='right'>渠道名称:</td>");
- leftQueryTable = leftQueryTable.concat("<td align='left'><input type='text' name='txtDepartmentName' class='selectUser_Input selectUser_inputCondition'/></td>");
- leftQueryTable = leftQueryTable.concat("<td colspan='2' align='center' ><a id='btn' href='#' name='btnQueryDepartment'>查询</a> </td>");
- leftQueryTable = leftQueryTable.concat("</tr></table>");
- leftQuery = createElement(".query", leftQueryTable, elementLeft);
- createLinkButton(leftQuery);
- var left_panel_warp = createElement("div[panel_postion='left']", "<div class='panel_Data' panel_postion='left'><ul name='departmentTree'></ul></div>", elementLeft);
- left_panel_warp.panel({
- width: 350,
- height: 450,
- title: '部门信息',
- closable: false,
- collapsible: true,
- minimizable: false,
- maximizable: false
- });
- var departmentName = leftQuery.find("input[name='txtDepartmentName']").val();
- tree = $(left_panel_warp.find("ul[name='departmentTree']")[0]).tree({
- url: ("/" + CMS_SystemConfig.VirtualDirectoryPath + ("/Common/GetSelectUserControlDepartmentTree?departmentName=" + departmentName).replace(CMS_SystemConfig.VirtualDirectoryPath, "")).replaceDoubleSlashesToSingle(),
- lines: true,
- onBeforeLoad: function (node, param) {
- if (node == null) {
- return true;
- } else {
- var children = $(this).tree("getChildren", node.target);
- if (children == "") {
- return true;
- } else {
- return false;
- }
- }
- },
- onClick: function (node) {
- DepartmentID = eval(node).id;
- getUserInfo();
- }
- });
- var rightQuery = '<p class="query_p right_query_Postion" pPostion="right_top">帐号/用户名:<input type="text" name="txtUserName" class="selectUser_Input"/> <a href="#" name="btnQueryUser">查询</a>';
- rightQuery = rightQuery.concat(" <a href='#' name='btnSelectOk' >确定</a></p>");
- rightTopQuey = createElement("p[pPostion='right_top']", rightQuery, elementRight);
- createLinkButton(rightTopQuey);
- var rightWaitChoise_paneDiv = createElement("div[panel_postion='right_middel']", "<div class='panel_Data' panel_postion='right_middel'></div>", elementRight);
- var waitChoisePanel = rightWaitChoise_paneDiv.panel({
- width: 380,
- title: '待选用户',
- closable: false,
- collapsible: true,
- minimizable: false,
- maximizable: false
- });
- var selectAndDeteButtonStr = "<p class='query_p' pPostion='right_bottom'><a href='#' name='btnselectWaitUser' >选择</a> <a href='#' name='btnDelete'>删除</a> </p>";
- var selectAndDeteButton = createElement("p[pPostion='right_bottom']", selectAndDeteButtonStr, elementRight);
- createLinkButton(selectAndDeteButton);
- var left_panel_warp = createElement("div[panel_postion='right_selectUser']", "<div class='panel_Data' panel_postion='right_selectUser'></div>", elementRight);
- var pitchOnPanel = left_panel_warp.panel({
- width: 380,
- height: 150,
- title: '已选用户',
- closable: false,
- collapsible: true,
- minimizable: false,
- maximizable: false
- });
- var waitTable = createElement("table[name='waitDataGrid']", createTableString("waitDataGrid"), waitChoisePanel);
- var pitchOnTable = createElement("table[name='pitchOnDataGrid']", createTableString("pitchOnDataGrid"), pitchOnPanel);
- waitDataGrid = InitGridFile(waitTable, true, ("/" + CMS_SystemConfig.VirtualDirectoryPath + ("/Common/GetSelectUserContorlViewPageList").replace(CMS_SystemConfig.VirtualDirectoryPath, "")).replaceDoubleSlashesToSingle());
- pitchOnDataGrid = (InitGridFile(pitchOnTable, false));
- //查询部门树
- registEvent(leftQuery.find("a:first"), "click", loadDepartmentTree);
- //选择用户
- registEvent(selectAndDeteButton.find("a:first"), "click", selectWaitUser);
- //删除用户
- registEvent($(selectAndDeteButton.find("a")[1]), "click", deleteSelectUser);
- //关闭
- registEvent(rightTopQuey.find("a:first"), "click", getUserInfo);
- close(handlers);
- } else {
- $("div[name='winWarp']").window('open');
- }
- };
- return { "show": show };
- };
- $.extend($.fn.validatebox.defaults.rules, {
- baseRequired: {
- validator: function (value, param) {
- return value && value != "";
- },
- message: '必填'
- },
- dropdownListRequired: {
- validator: function (value, param) {
- return value != "" && value != "-1" && value != "全部" && value != "请选择";
- },
- message: '必选'
- },
- mobile: {
- validator: function (value, param) {
- return (/^1\d{10}$/gi).test(value);
- },
- message: '手机号码格式不对'
- },
- telnumber: {
- validator: function (value, param) {
- return (/((\d{11})|^((\d{7,8})|(\d{4}|\d{3})-(\d{7,8})|(\d{4}|\d{3})-(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1})|(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1}))$)/gi).test(value);
- },
- message: '号码格式不对'
- },
- IDCard: {
- validator: function (value, param) {
- var idcard = value; //身份证号码
- var Errors = new Array(
- "验证通过!OK",
- "身份证号码位数不对!",
- "身份证号码出生日期超出范围或含有非法字符!",
- "身份证号码校验错误!",
- "身份证地区非法!"
- );
- var area = { 11: "北京", 12: "天津", 13: "河北", 14: "山西", 15: "内蒙古", 21: "辽宁", 22: "吉林", 23: "黑龙江", 31: "上海", 32: "江苏", 33: "浙江", 34: "安徽", 35: "福建", 36: "江西", 37: "山东", 41: "河南", 42: "湖北", 43: "湖南", 44: "广东", 45: "广西", 46: "海南", 50: "重庆", 51: "四川", 52: "贵州", 53: "云南", 54: "西藏", 61: "陕西", 62: "甘肃", 63: "青海", 64: "宁夏", 65: "新疆", 71: "台湾", 81: "香港", 82: "澳门", 91: "国外" };
- var idcard, Y, JYM;
- var S, M;
- var idcard_array = new Array();
- idcard_array = idcard.split("");
- //地区检验
- if (area[parseInt(idcard.substr(0, 2))] == null) {
- this.message = Errors[4];
- return false;
- }
- //身份号码位数及格式检验
- switch (idcard.length) {
- case 15:
- if ((parseInt(idcard.substr(6, 2)) + 1900) % 4 == 0 || ((parseInt(idcard.substr(6, 2)) + 1900) % 100 == 0 && (parseInt(idcard.substr(6, 2)) + 1900) % 4 == 0)) {
- ereg = /^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/; //测试出生日期的合法性
- } else {
- ereg = /^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/; //测试出生日期的合法性
- }
- if (ereg.test(idcard)) return true;
- else {
- this.message = Errors[2];
- return false;
- }
- break;
- case 18:
- //18位身份号码检测
- //出生日期的合法性检查
- //闰年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))
- //平年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))
- if (parseInt(idcard.substr(6, 4)) % 4 == 0 || (parseInt(idcard.substr(6, 4)) % 100 == 0 && parseInt(idcard.substr(6, 4)) % 4 == 0)) {
- ereg = /^[1-9][0-9]{5}(19|20)[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}[0-9Xx]$/; //闰年出生日期的合法性正则表达式
- } else {
- ereg = /^[1-9][0-9]{5}(19|20)[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9Xx]$/; //平年出生日期的合法性正则表达式
- }
- if (ereg.test(idcard)) {//测试出生日期的合法性
- //计算校验位
- S = (parseInt(idcard_array[0]) + parseInt(idcard_array[10])) * 7
- + (parseInt(idcard_array[1]) + parseInt(idcard_array[11])) * 9
- + (parseInt(idcard_array[2]) + parseInt(idcard_array[12])) * 10
- + (parseInt(idcard_array[3]) + parseInt(idcard_array[13])) * 5
- + (parseInt(idcard_array[4]) + parseInt(idcard_array[14])) * 8
- + (parseInt(idcard_array[5]) + parseInt(idcard_array[15])) * 4
- + (parseInt(idcard_array[6]) + parseInt(idcard_array[16])) * 2
- + parseInt(idcard_array[7]) * 1
- + parseInt(idcard_array[8]) * 6
- + parseInt(idcard_array[9]) * 3;
- Y = S % 11;
- M = "F";
- JYM = "10X98765432";
- M = JYM.substr(Y, 1); //判断校验位
- if (M == idcard_array[17]) return true; //检测ID的校验位
- else {
- this.message = Errors[3];
- return false;
- };
- }
- else {
- this.message = Errors[2];
- return false;
- };
- break;
- default:
- this.message = Errors[1];
- return false;
- break;
- }
- },
- message: '证件号码格式不对'
- },
- filterWord: {
- validator: function (value, param) {
- var returnValue = true;
- $(param[0]).each(function (i, item) {
- if (item == value) {
- returnValue = false;
- return false;
- }
- });
- return returnValue;
- },
- message: '敏感字过滤'
- },
- onlyNumber: {
- validator: function (value, param) {
- return (/^[0-9]\d*$/gi).test(value);
- },
- message: '仅允许输入数字'
- },
- onlyDiscount: {
- validator: function (value, param) {
- //^0\.[0-9]{1,2}$
- return (/^(?:0(?:\.(?!00)[0-9]{1,2})?|1)$/gi).test(value);
- // return (/^[1-9]([.]{1}[1-9])?$/gi).test(value);
- },
- message: '仅允许输入带二位小数的有效数字'
- },
- onlyChar: {
- validator: function (value, param) {
- return (/^[A-Za-z0-9]+$/gi).test(value);
- },
- message: '仅允许输入英文及数字'
- },
- onlyMoney: {
- validator: function (value, param) {
- return (/^-?\d+(\.\d{1,2})?$/gi).test(value);
- },
- message: '仅允许输入保留二位有效数字'
- }
- });
- $.extend($.fn.validatebox.methods, {
- remove: function (jq, newposition) {
- return jq.each(function () {
- $(this).removeClass("validatebox-text validatebox-invalid").unbind('focus.validatebox').unbind('blur.validatebox');
- });
- },
- reduce: function (jq, newposition) {
- return jq.each(function () {
- var opt = $(this).data().validatebox.options;
- $(this).addClass("validatebox-text").validatebox(opt);
- });
- }
- });
- $.extend($.fn.validatebox.methods, {
- removeForCombobox: function (jq, newposition) {
- return jq.each(function () {
- var comboxText = $(this).next().find("input").first();
- comboxText.removeClass("validatebox-text validatebox-invalid").unbind('focus.validatebox').unbind('blur.validatebox');
- });
- },
- reduceForCombobox: function (jq, newposition) {
- return jq.each(function () {
- var comboxText = $(this).next().find("input").first();
- var opt = comboxText.data().validatebox.options;
- comboxText.addClass("validatebox-text").validatebox(opt);
- });
- }
- });
- //2013-12-05 begin added by pengbb 新增ajax加载html内容控件
- /*用法:定义一个div,指定class 为 easyui-cmsLoadHtml
- <div class="easyui-cmsLoadHtml" data-options="url:'/Common/GetHtmlContent'" >
- </div>
- data-options参数如下:
- url:'/Common/GetHtmlContent',
- loadingMessage:'正在加载中...',
- postData : {}
- */
- (function ($) {
- $.parser.plugins.push("cmsLoadHtml");
- function _init(jq) {
- var opts = $.data(jq, "cmsLoadHtml").options;
- return { cmsLoadHtml: jq };
- }
- function _load(jq) {
- var opts = $.data(jq, "cmsLoadHtml").options;
- if (opts.url && opts.url != "") {
- if (opts.loadingMessage) {
- //loadPanel.prependTo(jq);
- var loadPanel = $("<div style=\"float:left;width:100%; height:100%;position:relative;\"></div>").prependTo(jq);
- $("<div style=\"clear:both;\"></div>").appendTo(jq);
- $("<div class=\"loadhtml-mask\" style=\"display:block\"></div>").appendTo(loadPanel);
- var msg = $("<div class=\"loadhtml-mask-msg\" style=\"display:block;left:50%\"></div>").html(opts.loadingMessage).appendTo(loadPanel);
- msg.css("marginLeft", -msg.outerWidth() / 2);
- }
- setTimeout(function () {
- $.ajax({
- url: opts.url,
- data: $.extend({}, {}, opts.postData),
- cache: false,
- dataType: "html",
- success: function (data) {
- $(jq).html(opts.extractor.call(jq, data));
- if (typeof (opts.onLoaded) == "function") {
- opts.onLoaded.call(jq);
- }
- }
- });
- }, opts.delay);
- }
- };
- $.fn.cmsLoadHtml = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsLoadHtml.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsLoadHtml(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var _jqThis = $(_this);
- var cacheData = $.data(_this, "cmsLoadHtml");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsLoadHtml", { options: $.extend({}, $.fn.cmsLoadHtml.defaults, $.fn.cmsLoadHtml.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsLoadHtml", $.extend({}, cacheData, initCacheData));
- }
- _load(_this);
- });
- };
- $.fn.cmsLoadHtml.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsLoadHtml").options;
- return opts;
- },
- reload: function (jq) {
- _load(jq[0]);
- }
- };
- $.fn.cmsLoadHtml.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsLoadHtml.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsLoadHtml.defaults = {
- url: '',
- delay: 0,
- loadingMessage: '正在加载中...',
- postData: {},
- onLoaded: function () { },
- extractor: function (data) {
- var _1ef = /<body[^>]*>((.|[\n\r])*)<\/body>/im;
- var _1f0 = _1ef.exec(data);
- if (_1f0) {
- return _1f0[1];
- } else {
- return data;
- }
- }
- };
- })(jQuery);
- //2013-12-05 end added by pengbb 新增ajax加载html内容控件
- //2013-12-10 begin added by pengbb 新增下一步审批人控件
- /*用法:定义一个div,指定class 为 easyui-cmsNextApproverSelector
- <div class="easyui-cmsNextApproverSelector" data-options="url:'/Common/GetHtmlContent'" >
- </div>
- data-options参数如下:
- url:'/Common/GetHtmlContent',
- loadingMessage:'正在加载中...',
- postData : {}
- */
- (function ($) {
- $.parser.plugins.push("cmsNextApproverSelector");
- function _init(jq) {
- var opts = $.data(jq, "cmsNextApproverSelector").options;
- var approverCombobox = $("<input />").attr("name", opts.name).appendTo(jq);
- var workPositionLabel = $("<label />").appendTo(jq);
- return { cmsNextApproverSelector: jq, approverCombobox: approverCombobox, workPositionLabel: workPositionLabel };
- }
- function _load(jq) {
- var opts = $.data(jq, "cmsNextApproverSelector").options;
- var approverCombobox = $.data(jq, "cmsNextApproverSelector").approverCombobox;
- var workPositionLabel = $.data(jq, "cmsNextApproverSelector").workPositionLabel;
- var loadingMessage = opts.loadingMessage || "系统正在加载下一步审批人中,请稍候...";
- var approverComboboxDefaultOptions = {
- multiple: false,
- panelHeight: 'auto',
- onSelect: function (record) {
- workPositionLabel.text(record.data[0].label);
- if (typeof (opts.onSelect) == "function") {
- opts.onSelect.call(jq);
- }
- },
- onLoadSuccess: function () {
- if (opts.showProgress) {
- //$.messager.progress('close');
- $.cmsLoading.hide();
- }
- if (approverCombobox.combobox("options").firstLoad) return;
- var getData = approverCombobox.combobox("getData");
- if (getData.length > 0) {
- if (getData[0].data[0].label == "结束") {
- approverCombobox.combobox("select", getData[0].id);
- workPositionLabel.text(getData[0].data[0].label);
- approverCombobox.combobox('disable');
- } else {
- approverCombobox.combobox('setValues', ['请选择']);
- }
- }
- if (typeof (opts.onLoadSuccess) == "function") {
- opts.onLoadSuccess.call(jq);
- }
- },
- onLoadError: function () {
- if (opts.showProgress) {
- //$.messager.progress('close');
- $.cmsLoading.hide();
- }
- //if (approverCombobox.combobox("options").firstLoad) return;
- if (typeof (opts.onLoadError) == "function") {
- opts.onLoadError.call(jq);
- }
- },
- //firstLoad: true,
- onBeforeLoad: function (param) {
- //alert(approverCombobox.combobox("options").firstLoad);
- //if (approverCombobox.combobox("options").firstLoad) {
- // approverCombobox.combobox("options").firstLoad = false;
- // return false;
- //}
- if (opts.showProgress) {
- //$.messager.progress({ msg: loadingMessage, autoClose: true, interval: 600 });
- $.cmsLoading.show(loadingMessage);
- }
- approverCombobox.combobox('enable');
- workPositionLabel.text("");
- $.extend(param, opts.postData);
- }
- };
- approverCombobox.combobox($.extend({}, opts, approverComboboxDefaultOptions));
- }
- $.fn.cmsNextApproverSelector = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsNextApproverSelector.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsNextApproverSelector(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var _jqThis = $(_this);
- var cacheData = $.data(_this, "cmsNextApproverSelector");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsNextApproverSelector", { options: $.extend({}, $.fn.cmsNextApproverSelector.defaults, $.fn.cmsNextApproverSelector.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsNextApproverSelector", $.extend({}, cacheData, initCacheData));
- }
- //cacheData.approverCombobox.combobox("reload");
- _load(_this);
- });
- };
- $.fn.cmsNextApproverSelector.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsNextApproverSelector").options;
- return opts;
- },
- reload: function (jq) {
- var approverCombobox = $.data(jq[0], "cmsNextApproverSelector").approverCombobox;
- approverCombobox.combobox("reload");
- },
- getData: function (jq) {
- var approverCombobox = $.data(jq[0], "cmsNextApproverSelector").approverCombobox;
- return approverCombobox.combobox("getData");
- },
- setValue: function (jq, val) {
- var approverCombobox = $.data(jq[0], "cmsNextApproverSelector").approverCombobox;
- approverCombobox.combobox("setValue", val);
- },
- setValues: function (jq, vals) {
- var approverCombobox = $.data(jq[0], "cmsNextApproverSelector").approverCombobox;
- approverCombobox.combobox("setValues", vals);
- },
- getValue: function (jq, vals) {
- var approverCombobox = $.data(jq[0], "cmsNextApproverSelector").approverCombobox;
- return approverCombobox.combobox("getValue");
- },
- getValues: function (jq, vals) {
- var approverCombobox = $.data(jq[0], "cmsNextApproverSelector").approverCombobox;
- return approverCombobox.combobox("getValues");
- },
- isValid: function (jq) {
- var t = $(jq);
- t.find(".validatebox-text:not(:disabled)").validatebox("validate");
- var _3dd = t.find(".validatebox-invalid");
- _3dd.filter(":not(:disabled):first").focus();
- return _3dd.length == 0;
- },
- validate: function (jq) {
- var approverCombobox = $.data(jq[0], "cmsNextApproverSelector").approverCombobox;
- return approverCombobox.combobox("validate");
- }
- };
- $.fn.cmsNextApproverSelector.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.extend({}, $.fn.cmsNextApproverSelector.defaults, $.parser.parseOptions(_7c7, ["valueField", "textField"])), $.fn.validatebox.parseOptions(_7c7));
- //return $.extend({}, $.fn.cmsNextApproverSelector.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsNextApproverSelector.defaults = {
- valueField: 'id',
- textField: 'text',
- url: '',
- loadingMessage: '',
- name: '',
- postData: {},
- showProgress: true,
- onSelect: function () { },
- onLoadSuccess: function () { },
- onLoadError: function () { }
- };
- })(jQuery);
- //2013-12-05 end added by pengbb 新增下一步审批人控件
- //2014-01-19 begin added by pengbb 新增下拉控件
- (function ($) {
- $.parser.plugins.push("cmsCombobox");
- function _getSelectedRecord(jq, selectedValue) {
- var opts = $.data(jq, "cmsCombobox").options;
- var reVal = null;
- $.each(opts.data, function () {
- if (this[opts.valueField] == selectedValue) {
- reVal = this;
- return false;
- }
- });
- return reVal;
- }
- function _init(jq) {
- var opts = $.data(jq, "cmsCombobox").options;
- var jqThis = $(jq);
- if (!opts.url) {
- opts.value = jq.value;
- opts.data = new Array();
- jqThis.find("option").each(function () {
- var rowRecord = new Object();
- rowRecord[opts.valueField] = this.value;
- rowRecord[opts.textField] = this.text;
- opts.data.push(rowRecord);
- });
- }
- $(jq).change(function () {
- opts.value = $(this).val();
- opts.onSelect.call(jq, _getSelectedRecord(jq, opts.value));
- });
- return { cmsCombobox: jq };
- }
- function _loadData(jq, data) {
- var opts = $.data(jq, "cmsCombobox").options;
- opts.data = data || [];
- var optionList = new Array();
- $.each(opts.data, function () {
- optionList.push("<option value=\"" + this[opts.valueField] + "\">" + opts.formatter.call(jq, this) + "</option>");
- });
- $(jq).html(optionList.join(""));
- opts.onLoadSuccess.apply(this);
- }
- function _load(jq) {
- var opts = $.data(jq, "cmsCombobox").options;
- if (opts.url) {
- var params = {};
- opts.onBeforeLoad.call(this, params);
- opts.loader.call(jq, params,
- function (responseJson) {
- _loadData(jq, responseJson);
- }, function () {
- opts.onLoadError.call(this, arguments);
- });
- } else {
- //opts.onLoadSuccess.call(this);
- }
- }
- function _setValue(jq, val) {
- //var opts = $.data(jq, "cmsCombobox").options;
- jq.value = val;
- }
- $.fn.cmsCombobox = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsCombobox.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsCombobox(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var _jqThis = $(_this);
- var cacheData = $.data(_this, "cmsCombobox");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsCombobox", { options: $.extend({}, $.fn.cmsCombobox.defaults, $.fn.cmsCombobox.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsCombobox", $.extend({}, cacheData, initCacheData));
- }
- _load(_this);
- });
- };
- $.fn.cmsCombobox.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsCombobox").options;
- return opts;
- },
- reload: function (jq) {
- },
- getValue: function (jq) {
- return jq.val();
- },
- setValue: function (jq, val) {
- jq.each(function () {
- _setValue(this, val);
- });
- },
- disable: function (jq) {
- jq.disable();
- },
- enable: function (jq) {
- jq.enable();
- }
- };
- $.fn.cmsCombobox.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.combo.parseOptions(_7c7), $.parser.parseOptions(_7c7, ["valueField", "textField", "mode", "method", "url"]));
- };
- $.fn.cmsCombobox.defaults = $.extend({}, $.fn.combo.defaults, {
- autoLoad: false,
- valueField: "value", textField: "text", mode: "local", method: "post", url: null, data: null,
- filter: function (q, row) {
- var opts = $(this).cmsCombobox("options");
- return row[opts.textField].indexOf(q) == 0;
- }, formatter: function (row) {
- var opts = $(this).cmsCombobox("options");
- return row[opts.textField];
- }, loader: function (_7c9, _7ca, _7cb) {
- var opts = $(this).cmsCombobox("options");
- if (!opts.url) {
- return false;
- }
- $.ajax({
- type: opts.method, url: opts.url, data: _7c9, dataType: "json", success: function (data) {
- _7ca(data);
- }, error: function () {
- _7cb.call(this, arguments);
- }
- });
- }, onBeforeLoad: function (_7cc) {
- }, onLoadSuccess: function () {
- }, onLoadError: function () {
- }, onSelect: function (_7cd) {
- }, onUnselect: function (_7ce) {
- }
- });
- })(jQuery);
- //2014-01-19 end added by pengbb 新增下拉控件
- //2013-12-05 begin added by pengbb 新增时间选择控件
- /*用法:指定class 为 easyui-cmsDatebox
- <span class="easyui-cmsDatebox cmsDateTimeBox">
- <input title="" style="width: auto;" readonly="false" class="cmsDateTimeBox-text" type="text">
- <span class="cmsDateTimeBox-select"></span>
- </span>
- */
- (function ($) {
- $.parser.plugins.push("cmsDateTimeBox");
- function _init(jq) {
- var opts = $.data(jq, "cmsDateTimeBox").options;
- var jqThis = $(jq);
- var jqTxtValue = jqThis.find("input.cmsDateTimeBox-text");
- var jqBtnSelect = jqThis.find("span.cmsDateTimeBox-select");
- var wdatePickerOptions = $.extend({}, opts, {
- el: jqTxtValue[0],
- onpicking: function () {
- }, onpicked: function () {
- opts.onSelect.call(jq);
- return true;
- }, onclearing: function () {
- }, oncleared: function () {
- }
- });
- jqBtnSelect.bind("mouseenter.cmsDateTimeBox", function () {
- $(this).addClass("cmsDateTimeBox-select-hover");
- }).bind("mouseleave.cmsDatebox", function () {
- $(this).removeClass("cmsDateTimeBox-select-hover");
- }).bind("mousedown.cmsDatebox", function () {
- WdatePicker(wdatePickerOptions);
- });
- jqTxtValue.click(function () {
- WdatePicker(wdatePickerOptions);
- });
- return { cmsDateTimeBox: jq, txtValue: jqTxtValue, btnSelect: jqBtnSelect };
- }
- $.fn.cmsDateTimeBox = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsDateTimeBox.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsDateTimeBox(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var _jqThis = $(_this);
- var cacheData = $.data(_this, "cmsDateTimeBox");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsDateTimeBox", { options: $.extend({}, $.fn.cmsDateTimeBox.defaults, $.fn.cmsDateTimeBox.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsDateTimeBox", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.cmsDateTimeBox.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsDateTimeBox").options;
- return opts;
- },
- getValue: function (jq) {
- var txtValue = $.data(jq[0], "cmsDateTimeBox").txtValue;
- return txtValue.val();
- },
- setValue: function (jq, val) {
- jq.each(function () {
- var txtValue = $.data(jq[0], "cmsDateTimeBox").txtValue;
- return txtValue.val(val);
- });
- }
- };
- $.fn.cmsDateTimeBox.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsDateTimeBox.defaults = $.extend({}, {}, {
- dateFmt: 'yyyy-MM-dd',
- lang: 'zh-cn',
- onSelect: function () {
- }
- });
- })(jQuery);
- //2014-01-20 end added by pengbb 新增时间选择控件
- //2014-01-21 begin added by pengbb 新增页面操作loading效果
- $.cmsLoading = (function () {
- var defaultSetting = {
- panelElement: document.body,
- defaultMessage: "正在努力处理中..."
- };
- var isInit = false;
- var loadingPanel = null;
- var f_getLoadingPanel = function () {
- return loadingPanel;
- };
- var f_show = function (msg) {
- if (!isInit) {
- this.setting.panelElement = this.setting.panelElement || document.body;
- loadingPanel = $('<div class="loading-panel"><div class="loading-mask" style="display:block"></div><div class="loading-mask-msg" style="display:block;left:46%;"></div></div>').appendTo(this.setting.panelElement);
- isInit = true;
- } else {
- loadingPanel.show();
- }
- loadingPanel.find("div.loading-mask-msg").html(msg || this.setting.defaultMessage);
- };
- var f_hide = function () {
- if (loadingPanel) {
- loadingPanel.hide();
- }
- };
- return { getLoadingPanel: f_getLoadingPanel, show: f_show, hide: f_hide, setting: defaultSetting };
- })();
- //2014-01-21 end added by pengbb 新增页面操作loading效果
- //2014-01-23 begin added by pengbb 新增下一步审批人控件,审批页面使用
- /*用法:定义一个div,指定class 为 easyui-cmsLocalNextApproverSelector
- <div class="easyui-cmsLocalNextApproverSelector" data-options="" >
- <select name="xxx"><option>xxx</option><option>xxx</option><option>xxx</option></select>
- <label></label>
- </div>
- data-options参数如下:
- url:'/Common/GetHtmlContent',
- loadingMessage:'正在加载中...',
- postData : {}
- */
- (function ($) {
- $.parser.plugins.push("cmsLocalNextApproverSelector");
- function _init(jq) {
- var opts = $.data(jq, "cmsLocalNextApproverSelector").options;
- var jqThis = $(jq);
- var approverCombobox = jqThis.find(">select");
- var workPositionLabel = jqThis.find(">label");
- approverCombobox.validatebox(opts);
- approverCombobox.unbind("cmsLocalNextApproverSelector");
- approverCombobox.bind("change.cmsLocalNextApproverSelector", function () {
- var selectedData = _getSelectedData(jq);
- if (selectedData && selectedData.ApprovalPower.length > 0) {
- workPositionLabel.text(selectedData.ApprovalPower[0].NodeName);
- } else {
- workPositionLabel.text("");
- }
- });
- //2014-02-20 end added by pengbb 修改IE8下 下一步审批人为"结束"时验证不通过
- if ($.browser.msie && $.browser.version > 6 && !approverCombobox.attr("disabled")) {
- approverCombobox.validatebox("validate");
- }
- return { cmsNextApproverSelector: jq, approverCombobox: approverCombobox, workPositionLabel: workPositionLabel };
- }
- function _getSelectedData(jq) {
- var opts = $.data(jq, "cmsLocalNextApproverSelector").options;
- var approverCombobox = $.data(jq, "cmsLocalNextApproverSelector").approverCombobox;
- var selectedValue = approverCombobox.val();
- var selectedData = null;
- $.each(opts.data, function () {
- if (this[opts.valueField] == selectedValue) {
- selectedData = this;
- return false;
- }
- });
- return selectedData;
- }
- function _loadData(jq, data) {
- var opts = $.data(jq, "cmsLocalNextApproverSelector").options;
- var approverCombobox = $.data(jq, "cmsLocalNextApproverSelector").approverCombobox;
- approverCombobox.enable();
- opts.data = data || [];
- var optionList = new Array();
- optionList.push("<option value=''>请选择</option>");
- $.each(opts.data, function () {
- if (this[opts.textField] == "结束") {
- optionList.length = 0;
- $(approverCombobox).attr("disabled", "disabled");
- }
- optionList.push("<option value=\"" + this[opts.valueField] + "\">" + opts.formatter.call(jq, this) + "</option>");
- });
- approverCombobox.html(optionList.join(""));
- opts.onLoadSuccess.apply(this);
- }
- function _reload(jq, url, postData) {
- var opts = $.data(jq, "cmsLocalNextApproverSelector").options;
- var approverCombobox = $.data(jq, "cmsLocalNextApproverSelector").approverCombobox;
- var workPositionLabel = $.data(jq, "cmsLocalNextApproverSelector").workPositionLabel;
- approverCombobox.disable();
- workPositionLabel.text("正在加载下一步审批人,请稍等...");
- $.ajax({
- type: "post", url: url, data: postData, dataType: "json", success: function (data) {
- workPositionLabel.text("");
- _loadData(jq, data);
- //解决点击下一步审批人下拉框缩回去的Bug
- if ($.browser.msie && $.browser.version > 6 && !approverCombobox.attr("disabled")) {
- approverCombobox.validatebox("validate");
- }
- }, error: function () {
- workPositionLabel.text("下一步审批人加载失败,请尝试重新打开,若多次出现这种请联系系统管理员");
- opts.onLoadError.apply(this, arguments);
- }
- });
- }
- $.fn.cmsLocalNextApproverSelector = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsLocalNextApproverSelector.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsLocalNextApproverSelector(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var _jqThis = $(_this);
- var cacheData = $.data(_this, "cmsLocalNextApproverSelector");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsLocalNextApproverSelector", { options: $.extend({}, $.fn.cmsLocalNextApproverSelector.defaults, $.fn.cmsLocalNextApproverSelector.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsLocalNextApproverSelector", $.extend({}, cacheData, initCacheData));
- }
- var opts = cacheData.options;
- if (opts.url && (!opts.data || opts.data.length == 0)) {
- _reload(_this, opts.url, opts.postData);
- }
- });
- };
- $.fn.cmsLocalNextApproverSelector.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsLocalNextApproverSelector").options;
- return opts;
- },
- reload: function (jq, p) {
- jq.each(function () {
- _reload(this, p.url, p.postData);
- });
- },
- getValue: function (jq) {
- var approverCombobox = $.data(jq[0], "cmsLocalNextApproverSelector").approverCombobox;
- return approverCombobox.val();
- },
- isValid: function (jq) {
- var t = $(jq);
- t.find("select:not(:disabled)").validatebox("validate");
- var _3dd = t.find(".validatebox-invalid");
- _3dd.filter(":not(:disabled):first").focus();
- return _3dd.length == 0;
- },
- validate: function (jq) {
- var approverCombobox = $.data(jq[0], "cmsLocalNextApproverSelector").approverCombobox;
- return approverCombobox.cmsCombobox("validate");
- }
- };
- $.fn.cmsLocalNextApproverSelector.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.extend({}, $.fn.cmsLocalNextApproverSelector.defaults, $.parser.parseOptions(_7c7, ["valueField", "textField"])), $.fn.validatebox.parseOptions(_7c7));
- //return $.extend({}, $.fn.cmsNextApproverSelector.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsLocalNextApproverSelector.defaults = {
- valueField: 'UserID',
- textField: 'UserName',
- url: '',
- loadingMessage: '',
- name: '',
- postData: {},
- data: [],
- showProgress: true,
- onSelect: function () { },
- onLoadSuccess: function () { },
- onLoadError: function () { },
- formatter: function (row) {
- var opts = $(this).cmsLocalNextApproverSelector("options");
- return row[opts.textField];
- }
- };
- })(jQuery);
- //2014-01-23 end added by pengbb 新增下一步审批人控件,审批页面使用
- //2014-02-21 begin added by pengbb 新增平铺品牌选择控件 cmsXBrandItemSelector
- (function ($) {
- $.parser.plugins.push("cmsXBrandItemSelector");
- function _init(jq) {
- var opts = $.data(jq, "cmsXBrandItemSelector").options;
- var _jqThis = $(jq);
- var brandPanel = _jqThis.find(".brandpanel");
- var brandItemPanel = _jqThis.find(".branditempanel");
- //品牌
- var brandXOptionItemList = brandPanel.find(".xoption2 table.xTabOption_item");
- brandXOptionItemList.unbind(".cmsXBrandItemSelector");
- brandXOptionItemList.bind("mouseenter.cmsXBrandItemSelector",
- function () {
- var _this = $(this);
- _this.addClass("xTabOption_item_hover");
- }
- );
- brandXOptionItemList.bind("mouseleave.cmsXBrandItemSelector",
- function () {
- var _this = $(this);
- _this.removeClass("xTabOption_item_hover");
- }
- );
- brandXOptionItemList.bind('click.cmsXBrandItemSelector', function () {
- var _this = $(this);
- if (!_this.hasClass("xTabOption_item_selected")) {
- brandPanel.find(".xTabOption_item_selected").each(function () {
- $(this).removeClass("xTabOption_item_selected");
- });
- _this.addClass("xTabOption_item_selected");
- brandPanel.trigger("selectChanged");
- }
- });
- brandPanel.unbind(".cmsXBrandItemSelector");
- brandPanel.bind("selectChanged.cmsXBrandItemSelector", function () {
- var selectValue = brandPanel.find("table.xTabOption_item_selected:first").attr("xoptionValue");
- if (selectValue != "-1") {
- brandItemPanel.show();
- } else {
- brandItemPanel.hide();
- }
- var brandItemPanelContent = brandItemPanel.find(".branditempanel_content");
- brandItemPanelContent.find("li.xoption").remove();
- $.each(opts.brandList, function () {
- if (this.BrandID == selectValue) {
- $.each(this.BrandItemList, function () {
- var newBrandItemLi = $('<LI class="xoption"><table class="xoption_item" cellpadding="0" cellspacing="0" border="0"><tr><td class="xoption_item_bg_left"> </td><td class="xoption_item_bg_center"> </td><td class="xoption_item_bg_right"> </td></tr></table></LI>').appendTo(brandItemPanelContent);
- newBrandItemLi.find("table").attr("xoptionValue", this.BrandItemID);
- newBrandItemLi.find("table td.xoption_item_bg_center").text(this.BrandItemName);
- });
- }
- });
- opts.selectChanged.call(jq);
- });
- //品牌物品
- var brandItemXOptionItemList = brandItemPanel.find("li.xoption table.xoption_item");
- brandItemXOptionItemList.die(".cmsXBrandItemSelector");
- brandItemXOptionItemList.live("mouseenter.cmsXBrandItemSelector",
- function () {
- var _this = $(this);
- _this.addClass("xoption_item_hover");
- }
- );
- brandItemXOptionItemList.live("mouseleave.cmsXBrandItemSelector",
- function () {
- var _this = $(this);
- _this.removeClass("xoption_item_hover");
- }
- );
- brandItemXOptionItemList.live("click.cmsXBrandItemSelector", function () {
- var _this = $(this);
- if (_this.hasClass("xoption_item_selected")) {
- _this.removeClass("xoption_item_selected");
- _this.find("td.xoption_item_bg_right>i").remove();
- } else {
- _this.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(_this.find("td.xoption_item_bg_right"));
- }
- brandItemPanel.trigger("selectChanged");
- });
- brandItemPanel.unbind(".cmsXBrandItemSelector");
- brandItemPanel.bind("selectChanged.cmsXBrandItemSelector", function () {
- opts.selectChanged.call(jq);
- });
- //清除所选按扭
- // brandItemPanel.find("li.branditempanel_tools .xbutton").unbind(".cmsXBrandItemSelector");
- // brandItemPanel.find("li.branditempanel_tools .xbutton").bind("click.cmsXBrandItemSelector", function () {
- // if (brandItemPanel.find("li.xoption_selected a").length > 0) {
- // brandItemPanel.find("li.xoption_selected a").each(function () {
- // var li = $(this).closest("li");
- // li.removeClass("xoption_selected");
- // li.find("i").remove();
- // });
- // brandItemPanel.trigger("selectChanged");
- // }
- // });
- return { cmsXBrandItemSelector: jq, brandPanel: brandPanel, brandItemPanel: brandItemPanel };
- }
- $.fn.cmsXBrandItemSelector = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsXBrandItemSelector.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsXBrandItemSelector(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsXBrandItemSelector");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsXBrandItemSelector", { options: $.extend({}, $.fn.cmsXBrandItemSelector.defaults, $.fn.cmsXBrandItemSelector.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsXBrandItemSelector", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- function _getValue(jq) {
- var opts = $.data(jq, "cmsXBrandItemSelector").options;
- var brandPanel = $.data(jq, "cmsXBrandItemSelector").brandPanel;
- var brandItemPanel = $.data(jq, "cmsXBrandItemSelector").brandItemPanel;
- var brandPayType = { BrandPayTypeID: "-1", BrandPayTypeName: "全部" };
- var brand = { BrandID: "-1", BrandName: "全部" };
- var brandItemList = [];
- brandPanel.find("table.xTabOption_item_selected:first").each(function () {
- var selectedBrand = $(this);
- brand = { BrandID: selectedBrand.attr("xoptionValue"), BrandName: selectedBrand.find("td.xTabOption_item_bg_center").text() };
- });
- brandItemPanel.find("table.xoption_item_selected").each(function () {
- var selectedBrandItem = $(this);
- brandItemList.push({
- BrandItemID: selectedBrandItem.attr("xoptionValue"),
- BrandItemName: selectedBrandItem.find("td.xoption_item_bg_center").text()
- });
- });
- return {
- BrandPayType: brandPayType,
- Brand: brand,
- BrandItemList: brandItemList
- };
- }
- function _clearBrandSelections(jq) {
- var brandPanel = $.data(jq, "cmsXBrandItemSelector").brandPanel;
- var brandItemPanel = $.data(jq, "cmsXBrandItemSelector").brandItemPanel;
- brandPanel.find("table.xTabOption_item_selected").removeClass("xTabOption_item_selected");
- var btnSelectAll = brandPanel.find("table.xTabOption_item[xoptionValue='-1']");
- btnSelectAll.addClass("xTabOption_item_selected");
- brandItemPanel.find("table.xoption_item").remove();
- brandItemPanel.hide();
- }
- function _clearBrandItemSelections(jq) {
- var brandItemPanel = $.data(jq, "cmsXBrandItemSelector").brandItemPanel;
- //brandItemPanel.find("table.xoption_item").remove();
- brandItemPanel.find("table.xoption_item_selected").removeClass("xoption_item_selected");
- //brandItemPanel.hide();
- }
- $.fn.cmsXBrandItemSelector.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsXBrandItemSelector").options;
- return opts;
- },
- getValue: function (jq) {
- return _getValue(jq[0]);
- },
- clearBrandSelections: function (jq) {
- jq.each(function () {
- _clearBrandSelections(this);
- });
- },
- clearBrandItemSelections: function (jq) {
- jq.each(function () {
- _clearBrandItemSelections(this);
- });
- }
- };
- $.fn.cmsXBrandItemSelector.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsXBrandItemSelector.defaults, $.parser.parseOptions(_7c7, ["valueField", "textField"]));
- };
- $.fn.cmsXBrandItemSelector.defaults = {
- selectChanged: function () {
- var val = $(this).cmsXBrandItemSelector("getValue");
- //alert(val.Brand.BrandName);
- //if (val.BrandItemList.length > 0) {
- // var ss = [];
- // $.each(val.BrandItemList, function () {
- // ss.push(this.BrandItemName);
- // });
- // alert(ss.join(","));
- //}
- },
- brandList: []
- };
- })(jQuery);
- //2014-02-21 end added by pengbb 新增平铺品牌选择控件
- //2014-02-24 begin added by pengbb 新增平铺选择控件 cmsXTileSelector
- (function ($) {
- $.parser.plugins.push("cmsXTileSelector");
- function _init(jq) {
- var opts = $.data(jq, "cmsXTileSelector").options;
- var _jqThis = $(jq);
- //var btnSelectAll = _jqThis.find(".col2 .selectall .xoption a");
- var tileItemPanel = _jqThis.find(".tileItemPanel,.tileItemPanel_more");
- if (tileItemPanel.find(".tileItemPanel_tools").length > 0) {
- var tileItemPanelMore = _jqThis.find(".tileItemPanel_more");
- var btnShowMore = tileItemPanel.find(".tileItemPanel_tools table.xbutton");
- btnShowMore.unbind(".cmsXTileSelector");
- btnShowMore.bind("click.cmsXTileSelector", function () {
- var btn = $(this);
- if (btn.hasClass("tileItemPanel_more_hide")) {
- btn.find("td.xbutton_bg_center").text("更多");
- btn.removeClass("tileItemPanel_more_hide");
- tileItemPanelMore.hide();
- } else {
- btn.addClass("tileItemPanel_more_hide");
- tileItemPanelMore.show();
- btn.find("td.xbutton_bg_center").text("收起");
- }
- });
- }
- //选项
- var optionItemList = tileItemPanel.find(".xoption table.xoption_item");
- var btnAllOptionItem = tileItemPanel.find(".xoption table.xoption_item[xoptionValue='-1']");
- optionItemList.unbind(".cmsXTileSelector");
- optionItemList.bind("mouseenter.cmsXTileSelector",
- function () {
- var _this = $(this);
- _this.addClass("xoption_item_hover");
- }
- );
- optionItemList.bind("mouseleave.cmsXTileSelector",
- function () {
- var _this = $(this);
- _this.removeClass("xoption_item_hover");
- }
- );
- optionItemList.bind('click.cmsXTileSelector', function () {
- var _this = $(this);
- var _thisValue = _this.attr("xoptionvalue");
- var isBtnAll = _thisValue == "-1";
- var isSelected = _this.hasClass("xoption_item_selected");
- if (opts.multiple) {
- if (isSelected && isBtnAll) return;
- if (_this.hasClass("xoption_item_selected")) {
- _this.removeClass("xoption_item_selected");
- _this.find("td.xoption_item_bg_right>i").remove();
- } else {
- _this.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(_this.find("td.xoption_item_bg_right"));
- }
- if (!isBtnAll) {
- if (tileItemPanel.find(".xoption table.xoption_item_selected").length > 0) {
- btnAllOptionItem.removeClass("xoption_item_selected");
- btnAllOptionItem.find("td.xoption_item_bg_right>i").remove();
- } else {
- btnAllOptionItem.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(btnAllOptionItem.find("td.xoption_item_bg_right"));
- }
- } else {
- var btnOtherOptionItemList = tileItemPanel.find(".xoption table.xoption_item[xoptionValue!='-1']");
- btnOtherOptionItemList.removeClass("xoption_item_selected");
- btnOtherOptionItemList.find("td.xoption_item_bg_right>i").remove();
- }
- } else {
- if (_this.hasClass("xoption_item_selected")) {
- return;
- } else {
- optionItemList.removeClass("xoption_item_selected");
- optionItemList.find("td.xoption_item_bg_right>i").remove();
- _this.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(_this.find("td.xoption_item_bg_right"));
- }
- }
- opts.selectChanged.call(jq);
- });
- return { cmsXTileSelector: jq, tileItemPanel: tileItemPanel };
- }
- $.fn.cmsXTileSelector = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsXTileSelector.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsXTileSelector(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsXTileSelector");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsXTileSelector", { options: $.extend({}, $.fn.cmsXTileSelector.defaults, $.fn.cmsXTileSelector.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsXTileSelector", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- function _getValue(jq) {
- var opts = $.data(jq, "cmsXTileSelector").options;
- var tileItemPanel = $.data(jq, "cmsXTileSelector").tileItemPanel;
- var selectedValueList = [];
- tileItemPanel.find("li.xoption table.xoption_item_selected").each(function () {
- var selectedItem = $(this);
- var selectedValue = new Object();
- selectedValue[opts.valueField] = selectedItem.attr("xoptionValue");
- selectedValue[opts.textField] = selectedItem.find("td.xoption_item_bg_center").text();
- selectedValueList.push(selectedValue);
- });
- return selectedValueList;
- }
- function _clearSelections(jq) {
- var tileItemPanel = $.data(jq, "cmsXTileSelector").tileItemPanel;
- tileItemPanel.find("li.xoption table.xoption_item_selected td.xoption_item_bg_right i").remove();
- tileItemPanel.find("li.xoption table.xoption_item_selected").removeClass("xoption_item_selected");
- var btnAllOptionItem = tileItemPanel.find("li.xoption table.xoption_item[xoptionValue='-1']");
- btnAllOptionItem.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(btnAllOptionItem.find("td.xoption_item_bg_right"));
- }
- $.fn.cmsXTileSelector.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsXTileSelector").options;
- return opts;
- },
- getValue: function (jq) {
- return _getValue(jq[0]);
- },
- clearSelections: function (jq) {
- jq.each(function () {
- _clearSelections(this);
- });
- }
- };
- $.fn.cmsXTileSelector.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsXTileSelector.defaults, $.parser.parseOptions(_7c7, ["valueField", "textField"]));
- };
- $.fn.cmsXTileSelector.defaults = {
- valueField: "Value",
- textField: "Text",
- selectChanged: function () {
- },
- multiple: true
- };
- })(jQuery);
- //2014-02-24 end added by pengbb 新增平铺品牌选择控件
- //2014-02-24 begin added by pengbb 新增平铺号码规则选择控件 cmsXTelnumberRuleSelector
- (function ($) {
- $.parser.plugins.push("cmsXTelnumberRuleSelector");
- function _init(jq) {
- var opts = $.data(jq, "cmsXTelnumberRuleSelector").options;
- var _jqThis = $(jq);
- var telnumberRuleTypePanel = _jqThis.find(".telnumberRuleTypePanel");
- var telnumberRulePanel = _jqThis.find(".telnumberRulePanel");
- //规则分类
- var telNumberRuleTypeOptionItemList = telnumberRuleTypePanel.find("li.telnumberRuleTypeItem table.xoption_item");
- telNumberRuleTypeOptionItemList.die(".cmsXTelnumberRuleSelector");
- telNumberRuleTypeOptionItemList.live("mouseenter.cmsXTelnumberRuleSelector",
- function () {
- var _this = $(this);
- _this.addClass("xoption_item_hover");
- }
- );
- telNumberRuleTypeOptionItemList.live("mouseleave.cmsXTelnumberRuleSelector",
- function () {
- var _this = $(this);
- _this.removeClass("xoption_item_hover");
- }
- );
- telNumberRuleTypeOptionItemList.live("click.cmsXTelnumberRuleSelector", function () {
- var _this = $(this);
- if (!_this.hasClass("xoption_item_selected")) {
- var oldSelectedTelNumberRuleTypeOptionItemList = telnumberRuleTypePanel.find("li.telnumberRuleTypeItem table.xoption_item_selected");
- oldSelectedTelNumberRuleTypeOptionItemList.removeClass("xoption_item_selected");
- oldSelectedTelNumberRuleTypeOptionItemList.find("td.xoption_item_bg_right>i").remove();
- _this.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(_this.find("td.xoption_item_bg_right"));
- telnumberRuleTypePanel.trigger("selectChanged");
- }
- });
- telnumberRuleTypePanel.unbind(".cmsXTelnumberRuleSelector");
- telnumberRuleTypePanel.bind("selectChanged.cmsXTelnumberRuleSelector", function () {
- telnumberRulePanel.find(".xoption").remove();
- var selectedTelNumberRuleTypeID = telnumberRuleTypePanel.find("li.telnumberRuleTypeItem table.xoption_item_selected:first").attr("xoptionValue");
- if (selectedTelNumberRuleTypeID == -1) {
- telnumberRulePanel.hide();
- //$.each(opts.telNumberRuleList, function () {
- // $.each(this.TelNumberRuleList, function () {
- // var newTelNumberRuleLi = $('<LI class="xoption"><A hideFocus href="javascript:void(0);" ><SPAN class="xoption_val"></SPAN></A></LI>').appendTo(telnumberRulePanel);
- // newTelNumberRuleLi.find("a>span").attr("xoptionValue", this.TelNumberRuleID);
- // newTelNumberRuleLi.find("a>span").text(this.TelNumberRuleName);
- // });
- //});
- } else {
- telnumberRulePanel.show();
- $.each(opts.telNumberRuleList, function () {
- if (this.TelNumberRuleTypeID == selectedTelNumberRuleTypeID) {
- $.each(this.TelNumberRuleList, function () {
- var newTelNumberRuleLi = $('<LI class="xoption"><table class="xoption_item" cellpadding="0" cellspacing="0" border="0"><tr><td class="xoption_item_bg_left"> </td><td class="xoption_item_bg_center"> </td><td class="xoption_item_bg_right"> </td></tr></table></LI>').appendTo(telnumberRulePanel);
- newTelNumberRuleLi.find("table").attr("xoptionValue", this.TelNumberRuleID);
- newTelNumberRuleLi.find("table td.xoption_item_bg_center").text(this.TelNumberRuleName);
- });
- }
- });
- }
- opts.selectChanged.call(jq);
- });
- //规则
- var telnumberRuleOptionItemList = telnumberRulePanel.find(".xoption table.xoption_item");
- telnumberRuleOptionItemList.die(".cmsXTelnumberRuleSelector");
- telnumberRuleOptionItemList.live("mouseenter.cmsXTelnumberRuleSelector",
- function () {
- var _this = $(this);
- _this.addClass("xoption_item_hover");
- }
- );
- telnumberRuleOptionItemList.live("mouseleave.cmsXTelnumberRuleSelector",
- function () {
- var _this = $(this);
- _this.removeClass("xoption_item_hover");
- }
- );
- telnumberRuleOptionItemList.live('click.cmsXTelnumberRuleSelector', function () {
- var _this = $(this);
- if (_this.hasClass("xoption_item_selected")) {
- _this.removeClass("xoption_item_selected");
- _this.find("td.xoption_item_bg_right>i").remove();
- } else {
- _this.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(_this.find("td.xoption_item_bg_right"));
- }
- telnumberRulePanel.trigger("selectChanged");
- });
- telnumberRulePanel.unbind(".cmsXTelnumberRuleSelector");
- telnumberRulePanel.bind("selectChanged.cmsXTelnumberRuleSelector", function () {
- opts.selectChanged.call(jq);
- });
- telnumberRulePanel.find(".telnumberRulePanelTool table.xbutton").die(".cmsXTelnumberRuleSelector");
- telnumberRulePanel.find(".telnumberRulePanelTool table.xbutton").live("click.cmsXTelnumberRuleSelector", function () {
- telnumberRulePanel.find(".xoption table.xoption_item").each(function () {
- var _this = $(this);
- if (!_this.hasClass("xoption_item_selected")) {
- _this.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(_this.find("td.xoption_item_bg_right"));
- }
- });
- telnumberRulePanel.trigger("selectChanged");
- });
- return { cmsXTelnumberRuleSelector: jq, telnumberRuleTypePanel: telnumberRuleTypePanel, telnumberRulePanel: telnumberRulePanel };
- }
- $.fn.cmsXTelnumberRuleSelector = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsXTelnumberRuleSelector.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsXTelnumberRuleSelector(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsXTelnumberRuleSelector");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsXTelnumberRuleSelector", { options: $.extend({}, $.fn.cmsXTelnumberRuleSelector.defaults, $.fn.cmsXTelnumberRuleSelector.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsXTelnumberRuleSelector", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- function _getValue(jq) {
- var opts = $.data(jq, "cmsXTelnumberRuleSelector").options;
- var telnumberRuleTypePanel = $.data(jq, "cmsXTelnumberRuleSelector").telnumberRuleTypePanel;
- var telnumberRulePanel = $.data(jq, "cmsXTelnumberRuleSelector").telnumberRulePanel;
- var selectedValueList = [];
- var selectedTelNumberRuleType = {};
- telnumberRuleTypePanel.find("li.telnumberRuleTypeItem table.xoption_item_selected:first").each(function () {
- selectedTelNumberRuleType["TelNumberRuleTypeID"] = $(this).attr("xoptionValue");
- selectedTelNumberRuleType["TelNumberRuleTypeName"] = $(this).find("td.xoption_item_bg_center").text();
- });
- telnumberRulePanel.find("table.xoption_item_selected").each(function () {
- var _this = $(this);
- selectedValueList.push({
- TelNumberRuleName: _this.find("td.xoption_item_bg_center").text(),
- TelNumberRuleID: _this.attr("xoptionValue")
- });
- });
- return { TelNumberRuleType: selectedTelNumberRuleType, TelNumberRuleList: selectedValueList };
- }
- function _clearSelections(jq) {
- var telnumberRuleTypePanel = $.data(jq, "cmsXTelnumberRuleSelector").telnumberRuleTypePanel;
- var telnumberRulePanel = $.data(jq, "cmsXTelnumberRuleSelector").telnumberRulePanel;
- var selectedTelnumberRuleTypeOptionItemList = telnumberRuleTypePanel.find("li.telnumberRuleTypeItem table.xoption_item_selected");
- selectedTelnumberRuleTypeOptionItemList.removeClass("xoption_item_selected");
- selectedTelnumberRuleTypeOptionItemList.find("td.xoption_item_bg_right>i").remove();
- var telnumberRuleTypePanelSelectAll = telnumberRuleTypePanel.find("li.telnumberRuleTypeItem table.xoption_item[xoptionValue='-1']");
- telnumberRuleTypePanelSelectAll.addClass("xoption_item_selected");
- $('<i class="xoption_item_icon_selected" > </i>').appendTo(telnumberRuleTypePanelSelectAll.find("td.xoption_item_bg_right"));
- telnumberRulePanel.find("li.xoption table.xoption_item_selected td.xoption_item_bg_right i").remove();
- telnumberRulePanel.find("li.xoption table.xoption_item_selected").removeClass("xoption_item_selected");
- telnumberRulePanel.hide();
- }
- function _load(jq, param) {
- var opts = $.data(jq, "cmsXTelnumberRuleSelector").options;
- param = $.extend({}, { url: '', postData: {} }, param);
- if (param.url) {
- $.ajax({
- type: "post", url: param.url, data: param.postData, dataType: "json", success: function (data) {
- _loadData(jq, data);
- }, error: function () {
- if (typeof (opts.onLoadError) == "function") {
- opts.onLoadError.call(jq);
- }
- }
- });
- }
- }
- function _loadData(jq, data) {
- var opts = $.data(jq, "cmsXTelnumberRuleSelector").options;
- var telnumberRuleTypePanel = $.data(jq, "cmsXTelnumberRuleSelector").telnumberRuleTypePanel;
- var telnumberRulePanel = $.data(jq, "cmsXTelnumberRuleSelector").telnumberRulePanel;
- opts.telNumberRuleList = data || [];
- telnumberRuleTypePanel.find("li.telnumberRuleTypeItem").remove();
- telnumberRulePanel.find("li.xoption").remove();
- telnumberRulePanel.hide();
- $('<li class="telnumberRuleTypeItem"><table class="xoption_item xoption_item_selected" xoptionValue="-1" cellpadding="0" cellspacing="0"border="0"><tr><td class="xoption_item_bg_left"> </td><td class="xoption_item_bg_center">全部</td><td class="xoption_item_bg_right"> <i class="xoption_item_icon_selected"> </i></td></tr></table></li>').appendTo(telnumberRuleTypePanel);
- $.each(opts.telNumberRuleList, function () {
- var newTelNumberRuleTypeLi = $('<LI class="telnumberRuleTypeItem"><table class="xoption_item" cellpadding="0" cellspacing="0" border="0"><tr><td class="xoption_item_bg_left"> </td><td class="xoption_item_bg_center"> </td><td class="xoption_item_bg_right"> </td></tr></table></LI>').appendTo(telnumberRuleTypePanel);
- newTelNumberRuleTypeLi.find("table").attr("xoptionValue", this.TelNumberRuleTypeID);
- newTelNumberRuleTypeLi.find("table td.xoption_item_bg_center").text(this.TelNumberRuleTypeName);
- //$.each(this.TelNumberRuleList,function() {
- // var newTelNumberRuleLi = $('<LI class="xoption"><A hideFocus href="javascript:void(0);" ><SPAN class="xoption_val"></SPAN></A></LI>').appendTo(telnumberRulePanel);
- // newTelNumberRuleLi.find("a>span").attr("xoptionValue", this.TelNumberRuleID);
- // newTelNumberRuleLi.find("a>span").text(this.TelNumberRuleName);
- //});
- });
- if (typeof (opts.onLoadSuccess) == "function") {
- opts.onLoadSuccess.call(jq);
- }
- }
- $.fn.cmsXTelnumberRuleSelector.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsXTelnumberRuleSelector").options;
- return opts;
- },
- getTelNumberRuleList: function (jq) {
- var opts = $.data(jq[0], "cmsXTelnumberRuleSelector").options;
- return opts.telNumberRuleList;
- },
- getValue: function (jq) {
- return _getValue(jq[0]);
- },
- clearSelections: function (jq) {
- jq.each(function () {
- _clearSelections(this);
- });
- },
- //param:{url:'',postData:{}}
- load: function (jq, param) {
- jq.each(function () {
- _load(this, param);
- });
- }
- };
- $.fn.cmsXTelnumberRuleSelector.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsXTelnumberRuleSelector.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsXTelnumberRuleSelector.defaults = {
- selectChanged: function () {
- //alert(JSON.stringify($(this).cmsXTelnumberRuleSelector("getValue")));
- //alert(0);
- },
- multiple: true,
- telNumberRuleList: [],
- onLoadSuccess: function (data) {
- },
- onLoadError: function () {
- }
- };
- })(jQuery);
- //2014-02-24 end added by pengbb 新增平铺号码规则选择控件
- //2014-02-25 begin added by pengbb 新增号码精确查询输入控件 cmsXExactTelNumberInput
- (function ($) {
- $.parser.plugins.push("cmsXExactTelNumberInput");
- function _init(jq) {
- var opts = $.data(jq, "cmsXExactTelNumberInput").options;
- var _jqThis = $(jq);
- var numberInputList = _jqThis.find("li.numbercolumn span.numberinput>input");
- var btnOK = _jqThis.find("li.toolcolumn .xbutton");
- numberInputList.unbind(".cmsXExactTelNumberInput");
- numberInputList.bind("keydown.cmsXExactTelNumberInput", function (event) {
- //48-57,96-105,退格:8,左:37,右:39
- var keyCode = event.keyCode;
- if (!((48 <= keyCode && keyCode <= 57) || (96 <= keyCode && keyCode <= 105) || keyCode == 8)) {
- return false;
- }
- this.value = "";
- });
- numberInputList.bind("keyup.cmsXExactTelNumberInput", function (event) {
- var keyCode = event.keyCode;
- if (keyCode == 37) {
- $(this).closest("li").prev("li").find("span.numberinput>input").focus();
- } else if (keyCode == 39) {
- $(this).closest("li").next("li").find("span.numberinput>input").focus();
- } else {
- if (this.value != "") {
- $(this).closest("li").next("li").find("span.numberinput>input").focus();
- } else {
- if (keyCode == 8) {
- $(this).closest("li").prev("li").find("span.numberinput>input").focus().val("");
- }
- }
- }
- });
- btnOK.unbind(".cmsXExactTelNumberInput");
- btnOK.bind("click.cmsXExactTelNumberInput", function () {
- opts.inputCompleted.call(jq, _getValue(jq));
- });
- return { cmsXExactTelNumberInput: jq, numberInputList: numberInputList, btnOK: btnOK };
- }
- $.fn.cmsXExactTelNumberInput = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsXExactTelNumberInput.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsXExactTelNumberInput(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsXExactTelNumberInput");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsXExactTelNumberInput", { options: $.extend({}, $.fn.cmsXExactTelNumberInput.defaults, $.fn.cmsXExactTelNumberInput.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsXExactTelNumberInput", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- function _getValue(jq) {
- var opts = $.data(jq, "cmsXExactTelNumberInput").options;
- var numberInputList = $.data(jq, "cmsXExactTelNumberInput").numberInputList;
- var valueList = [];
- numberInputList.each(function () {
- if (this.value == "") {
- valueList.push("_");
- } else {
- valueList.push(this.value);
- }
- });
- return valueList.join("");
- }
- function _reset(jq) {
- var numberInputList = $.data(jq, "cmsXExactTelNumberInput").numberInputList;
- numberInputList.each(function () {
- this.value = "";
- });
- };
- $.fn.cmsXExactTelNumberInput.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsXExactTelNumberInput").options;
- return opts;
- },
- getValue: function (jq) {
- return _getValue(jq[0]);
- },
- reset: function (jq) {
- jq.each(function () {
- _reset(this);
- });
- }
- };
- $.fn.cmsXExactTelNumberInput.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsXExactTelNumberInput.defaults, $.parser.parseOptions(_7c7, ["valueField", "textField"]));
- };
- $.fn.cmsXExactTelNumberInput.defaults = {
- inputCompleted: function (val) {
- //alert("value:" + $(this).cmsXExactTelNumberInput("getValue"));
- }
- };
- })(jQuery);
- //2014-02-25 end added by pengbb 新增号码精确查询输入控件
- //2014-02-25 begin added by pengbb 新增已选条件控件 cmsXSelectedCondition
- (function ($) {
- $.parser.plugins.push("cmsXSelectedCondition");
- function _init(jq) {
- var opts = $.data(jq, "cmsXSelectedCondition").options;
- var _jqThis = $(jq);
- var selectedConditionPanel = _jqThis.find(".selectedConditionPanel");
- var conditionTool = selectedConditionPanel.find("li.conditionTool");
- var conditionItemPanel = selectedConditionPanel;
- var btnReset = conditionTool.find("table.xbutton_reset");
- var btnQuery = conditionTool.find("table.xbutton_query");
- btnReset.unbind(".cmsXSelectedCondition");
- btnReset.bind("click.cmsXSelectedCondition", function () {
- conditionItemPanel.find(">li.conditionItem").remove();
- conditionItemPanel.trigger("onItemChanged");
- opts.onReset.call(jq);
- });
- btnQuery.unbind(".cmsXSelectedCondition");
- btnQuery.bind("click.cmsXSelectedCondition", function () {
- var formDataJson = _getConditionJson(jq);
- opts.onQuery.call(jq, formDataJson);
- });
- conditionItemPanel.find(">li.conditionItem i").die(".cmsXSelectedCondition");
- conditionItemPanel.find(">li.conditionItem i").live("click.cmsXSelectedCondition", function () {
- var li = $(this).closest("li");
- li.remove();
- var d = new Object();
- d.name = li.attr("conditionName");
- d.value = li.attr("conditionValue");
- opts.onConditionRemoved.call(jq, d);
- conditionItemPanel.trigger("onItemChanged");
- });
- conditionItemPanel.unbind("onItemChanged.cmsXSelectedCondition");
- conditionItemPanel.bind("onItemChanged.cmsXSelectedCondition", function () {
- var formDataJson = _getConditionJson(jq);
- opts.onConditionChanged.call(jq, formDataJson);
- });
- //$('<LI class="conditionItem"><span class="conditionText">百万号段:全部 <i class="deleteButton"> </i></span></LI>').appendTo(conditionItemPanel);
- return { cmsXSelectedCondition: jq, selectedConditionPanel: selectedConditionPanel, conditionItemPanel: conditionItemPanel, conditionTool: conditionTool, btnQuery: btnQuery, btnReset: btnReset };
- }
- $.fn.cmsXSelectedCondition = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsXSelectedCondition.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsXSelectedCondition(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsXSelectedCondition");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsXSelectedCondition", { options: $.extend({}, $.fn.cmsXSelectedCondition.defaults, $.fn.cmsXSelectedCondition.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsXSelectedCondition", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- function _getConditionJson(jq) {
- var opts = $.data(jq, "cmsXSelectedCondition").options;
- var conditionItemPanel = $.data(jq, "cmsXSelectedCondition").conditionItemPanel;
- var formDataJson = new Object();
- conditionItemPanel.find("li.conditionItem").each(function () {
- var jqItem = $(this);
- var d = new Object();
- d.name = jqItem.attr("conditionName");
- d.value = jqItem.attr("conditionValue");
- if (d.name) {
- if (formDataJson[d.name]) {
- formDataJson[d.name] += "," + d.value;
- } else {
- formDataJson[d.name] = d.value;
- }
- }
- });
- return formDataJson;
- }
- //condition:{name:'',value:'',text:''}
- function _addCondition(jq, condition) {
- var opts = $.data(jq, "cmsXSelectedCondition").options;
- var conditionItemPanel = $.data(jq, "cmsXSelectedCondition").conditionItemPanel;
- if (condition && condition.name && condition.text) {
- var newConditionLi = conditionItemPanel.find("li.conditionItem[conditionName='" + condition.name + "']");
- if (newConditionLi.length == 0) {
- newConditionLi = $('<LI class="conditionItem"><span class="conditionText"><p></p><i class="deleteButton"> </i></span></LI>').appendTo(conditionItemPanel);
- }
- newConditionLi.attr("conditionName", condition.name);
- newConditionLi.attr("conditionValue", condition.value);
- newConditionLi.find(">span>p").html(condition.text);
- conditionItemPanel.trigger("onItemChanged");
- }
- }
- function _removeCondition(jq, conditionName) {
- var opts = $.data(jq, "cmsXSelectedCondition").options;
- var conditionItemPanel = $.data(jq, "cmsXSelectedCondition").conditionItemPanel;
- var a = conditionItemPanel.find("li.conditionItem[conditionName='" + conditionName + "']");
- if (a.length > 0) {
- a.remove();
- conditionItemPanel.trigger("onItemChanged");
- }
- }
- $.fn.cmsXSelectedCondition.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsXSelectedCondition").options;
- return opts;
- },
- getConditionJson: function (jq) {
- return _getConditionJson(jq[0]);
- },
- //condition:{name:'',value:'',text:''}
- addCondition: function (jq, condition) {
- jq.each(function () {
- _addCondition(this, condition);
- });
- },
- removeCondition: function (jq, conditionName) {
- jq.each(function () {
- _removeCondition(this, conditionName);
- });
- }
- };
- $.fn.cmsXSelectedCondition.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsXSelectedCondition.defaults, $.parser.parseOptions(_7c7, ["valueField", "textField"]));
- };
- $.fn.cmsXSelectedCondition.defaults = {
- onConditionChanged: function (formDataJson) {
- //alert("onConditionChanged:" + JSON.stringify(formDataJson));
- },
- onQuery: function (formDataJson) {
- //alert("onQuery:" + JSON.stringify(formDataJson));
- },
- onConditionRemoved: function (removedCondition) {
- },
- onReset: function () {
- }
- };
- })(jQuery);
- //2014-02-25 end added by pengbb 新增已选条件控件
- //2014-02-28 begin added by pengbb 新增cmsXDataTable
- (function ($) {
- $.parser.plugins.push("cmsXDataTable");
- function _init(jq) {
- var opts = $.data(jq, "cmsXDataTable").options;
- var _jqThis = $(jq);
- var header = _jqThis.find(">div.xDataTable_bodyPanel .xDataTableHeader");
- var table = _jqThis.find(">div.xDataTable_bodyPanel .xDataTable");
- var parentCtrl = _jqThis.parent();
- var totalWidth = 0;
- var columnList = new Array();
- var contentContainer = table.parent();
- // var container = _jqThis.find(".xDataTable_container");
- // container.scroll(function () {
- // table.find("tr.header").css("top", container.scrollTop());
- // });
- //初始化列属性
- var columnIndex = 0;
- header.find("tr.header>th").each(function () {
- var jqThColumn = $(this);
- var newColumn = $.extend({}, $.fn.cmsXDataTable.column.defaults, $.parser.parseOptions(jqThColumn, []));
- // newColumn.columnType = $(this).attr("columnType");
- // if(newColumn.columnType)
- // newColumn.columnType = newColumn.columnType.replace(/[\']*/g, "");
- if (newColumn.validateOption) {
- if (newColumn.validateOption.required == "true") {
- newColumn.validateOption.required = true;
- }
- else {
- newColumn.validateOption.required = false;
- }
- }
- newColumn.columnIndex = (columnIndex++);
- newColumn.element = this;
- if (newColumn.columnType == "checkbox") {
- jqThColumn.find("input[type='checkbox']").unbind(".cmsXDataTable");
- jqThColumn.find("input[type='checkbox']").bind("click.cmsXDataTable", function () {
- var isChecked = !!$(this).attr("checked");
- var allRow = table.find("tr.row>td[columnIndex='" + newColumn.columnIndex + "'] input[type='checkbox']");
- allRow.attr("checked", isChecked);
- if (isChecked) {
- allRow.closest("tr").addClass("row_selected");
- } else {
- allRow.closest("tr").removeClass("row_selected");
- }
- });
- table.find("tr.row>td[columnIndex='" + newColumn.columnIndex + "'] input[type='checkbox']").die(".cmsXDataTable");
- table.find("tr.row>td[columnIndex='" + newColumn.columnIndex + "'] input[type='checkbox']").live("click.cmsXDataTable", function () {
- var isChecked = !!$(this).attr("checked");
- if (isChecked) {
- $(this).closest("tr").addClass("row_selected");
- } else {
- $(this).closest("tr").removeClass("row_selected");
- }
- });
- newColumn.width = 24;
- }
- else {
- if (newColumn.width) {
- if (newColumn.width < 1) {
- newColumn.width = parentCtrl.width() * newColumn.width;
- }
- } else if (header.find("tr.header>th").length > 0){
- newColumn.width = parseInt(parentCtrl.width() / header.find("tr.header>th").length);
- }
- }
- if (newColumn.hidden) {
- jqThColumn[0].style.display = "none";
- }
- jqThColumn.attr('align', newColumn.align);
- jqThColumn.css("width", newColumn.width + "px");
- totalWidth += newColumn.width;
- columnList.push(newColumn);
- });
- var comboGrid = header.parents('.easyui-combogridX:first');
- if (comboGrid.length > 0) {
- if ((totalWidth + 24) > 150) {
- comboGrid.find('.combogridX-expander').width(totalWidth + 24);
- } else {
- comboGrid.find('.combogridX-expander').width(150);
- }
- }
-
- _calMaxSize(jq);
- var pagerPanel = _jqThis.find(".xDataTablePanel_pager");
- if (opts.pagerType == 0 && opts.pagination) {
- pagerPanel.find("input.xDataTablePanel_pager-page-list").unbind("cmsXDataTable");
- pagerPanel.find("input.xDataTablePanel_pager-page-list").bind("blur.cmsXDataTable", function () {
- opts.pageNumber = 1;
- opts.pageSize = $(this).val();
- _load(jq, opts.queryParams, false);
- });
- pagerPanel.find("input.xDataTablePanel_pager-page-list").bind("keydown.cmsXDataTable", function () {
- var keyCode = event.keyCode;
- if (!((48 <= keyCode && keyCode <= 57) || (96 <= keyCode && keyCode <= 105) || keyCode == 8 || keyCode == 13)) {
- return false;
- }
- });
- pagerPanel.find("input.xDataTablePanel_pager-page-list").bind("keyup.cmsXDataTable", function () {
- var keyCode = event.keyCode;
- if (!((48 <= keyCode && keyCode <= 57) || (96 <= keyCode && keyCode <= 105) || keyCode == 8 || keyCode == 13)) {
- return false;
- }
-
- if ($(this).val() >= 500) $(this).val(500);
- //enter
- if (keyCode == 13) {
- $(this).blur();
- opts.pageNumber = 1;
- opts.pageSize = $(this).val();
- _load(jq, opts.queryParams, false);
- }
- });
- pagerPanel.find("input.xDataTablePanel_pager-num").unbind("cmsXDataTable");
- pagerPanel.find("input.xDataTablePanel_pager-num").bind("keydown.cmsXDataTable", function () {
- var keyCode = event.keyCode;
- if (!((48 <= keyCode && keyCode <= 57) || (96 <= keyCode && keyCode <= 105) || keyCode == 8 || keyCode == 13)) {
- return false;
- }
- });
- pagerPanel.find("input.xDataTablePanel_pager-num").bind("keyup.cmsXDataTable", function () {
- var keyCode = event.keyCode;
- if (!((48 <= keyCode && keyCode <= 57) || (96 <= keyCode && keyCode <= 105) || keyCode == 8 || keyCode == 13)) {
- return false;
- }
- //enter
- if (keyCode == 13) {
- $(this).blur();
- var newPageNumber = $.trim($(this).val());
- if (newPageNumber != "") {
- opts.pageNumber = parseInt(newPageNumber);
- _load(jq, opts.queryParams, false);
- }
- }
- });
- var btnPagerFirst = pagerPanel.find("a.pager-first");
- btnPagerFirst.unbind("cmsXDataTable");
- btnPagerFirst.bind("click.cmsXDataTable", function () {
- if ($(this).hasClass("l-btn-disabled")) {
- return false;
- }
- opts.pageNumber = 1;
- _load(jq, opts.queryParams, false);
- });
- var btnPagerPrev = pagerPanel.find("a.pager-prev");
- btnPagerPrev.unbind("cmsXDataTable");
- btnPagerPrev.bind("click.cmsXDataTable", function () {
- if ($(this).hasClass("l-btn-disabled")) {
- return false;
- }
- opts.pageNumber = opts.pageNumber - 1;
- _load(jq, opts.queryParams, false);
- });
- var btnPagerNext = pagerPanel.find("a.pager-next");
- btnPagerNext.unbind("cmsXDataTable");
- btnPagerNext.bind("click.cmsXDataTable", function () {
- if ($(this).hasClass("l-btn-disabled")) {
- return false;
- }
- opts.pageNumber = opts.pageNumber + 1;
- _load(jq, opts.queryParams, false);
- });
- var btnPagerLast = pagerPanel.find("a.pager-last");
- btnPagerLast.unbind("cmsXDataTable");
- btnPagerLast.bind("click.cmsXDataTable", function () {
- if ($(this).hasClass("l-btn-disabled")) {
- return false;
- }
- opts.pageNumber = opts.totalPage;
- _load(jq, opts.queryParams, false);
- });
- } else {
- var btnPagerNext = pagerPanel.find(".xDataTablePanel_pager_Simp");
- btnPagerNext.unbind("cmsXDataTable");
- btnPagerNext.bind("click.cmsXDataTable", function () {
- if ($(this).hasClass("l-btn-disabled")) {
- return false;
- }
- opts.pageNumber = opts.pageNumber + 1;
- _load(jq, opts.queryParams, false);
- });
- }
- contentContainer.scroll(function() {
- var headerContainer = header.parent();
- headerContainer.scrollLeft($(this).scrollLeft());
- });
- return { cmsXDataTable: jq, table: table, totalWidth: totalWidth, header: header, columnList: columnList, pagerPanel: pagerPanel, btnPagerFirst: btnPagerFirst, btnPagerPrev: btnPagerPrev, btnPagerNext: btnPagerNext, btnPagerLast: btnPagerLast };
- }
- var _loadAll = function (jq, formData) {
- var table = $.data(jq, "cmsXDataTable").table;
- var opts = $.data(jq, "cmsXDataTable").options;
- table.find("tr.row").remove();
- opts.data = { total: 0, rows: [] };
- _load(jq, formData, true);
- };
- var _calMaxSize = function (jq) {
- var opts = $.data(jq, "cmsXDataTable").options;
-
- if (opts.pagerType == 0) {
- var tablePanel = $(jq).find(".xDataTable").parent();
- if (opts.maxHeight) {
- tablePanel.css("maxHeight", opts.maxHeight + "px");
- } else {
- var documentHeight = $(document).height();
- // var bodyHeigh = $("body").height();
- // var bodyTop = $('body').offset().top;
- // var tablePanelHeight = tablePanel.height();
- var maxHeight = documentHeight - 4 - tablePanel.offset().top - $(jq).find(".xDataTablePanel_pager").height();
-
- //教务系统的特殊情况start
- if ($("#BatchModifydiv").length > 0) {
- if ($("#BatchModifydiv").css("display") != "none") {
- maxHeight += $("#BatchModifydiv").height();
- }
- }
- //教务系统的特殊情况end
- // if ((bodyHeigh - tablePanelHeight + maxHeight) > (documentHeight - bodyTop - 30))
- // {
- // maxHeight = maxHeight - ((bodyHeigh - tablePanelHeight + maxHeight) - (documentHeight - bodyTop - 30));
- // }
- tablePanel.css("maxHeight", maxHeight + "px");
- }
- }
- };
- var _load = function (jq, formData, isLoadAll, orderby, isAsc) {
- var opts = $.data(jq, "cmsXDataTable").options;
- var table = $.data(jq, "cmsXDataTable").table;
- var parent = table.closest(".xDataTable_bodyPanel");
- if (!table.css("height") || table.css("height") == "") {
- parent.css("height", "100%;");
- }
- if (typeof (opts.onBeforeLoad) == "function" && opts.onBeforeLoad.call(jq, formData) == false) {
- return;
- }
- //loading msg
- if (opts.loadMsg) {
- $("<div class=\"datagrid-mask\" style=\"display:block\"></div>").appendTo(jq).height($(jq).outerHeight());
- var msg = $("<div class=\"datagrid-mask-msg\" style=\"display:block;left:50%\"></div>").html(opts.loadMsg).appendTo(jq);
- msg.css("marginLeft", -msg.outerWidth() / 2);
- }
- opts.queryParams = formData || opts.queryParams;
- if (opts.pagination) {
- formData = $.extend({}, opts.queryParams, { page: opts.pageNumber - 1, rows: opts.pageSize });
- if (orderby) {
- formData = $.extend({}, formData, { OrderBy: orderby, IsAsc: isAsc });
- }
- } else if (orderby) {
- formData = $.extend({}, opts.queryParams, { OrderBy: orderby, IsAsc: isAsc });
- }
- if (!orderby) {
- _clearOrderByAsc(jq);
- }
- $.ajax({
- type: "post", url: opts.url, data: formData, dataType: "json", success: function (data) {
- data = $.extend({}, { total: 0, rows: [] }, data);
- $(jq).find(".datagrid-mask,.datagrid-mask-msg").remove();
- _loadData(jq, data, isLoadAll);
- }, error: function (e) {
- $(jq).find(".datagrid-mask,.datagrid-mask-msg").remove();
- if (typeof (opts.onLoadError) == "function") {
- opts.onLoadError.call(jq);
- }
- }
- });
- };
- var _getHighlightProp = function (jq, rowIndex) {
- var opts = $.data(jq, "cmsXDataTable").options;
- var row = opts.data.rows[rowIndex];
- var result = "";
- if (opts.rowHighlightColor) {
- if (opts.rowHighlightFun) {
- if (opts.rowHighlightFun.call(this, rowIndex, row)) {
- result = " style=\"background-color: " + opts.rowHighlightColor + "\"";
- }
- }
- }
- return result;
- }
- var _loadData = function (jq, data, isLoadAll) {
- var opts = $.data(jq, "cmsXDataTable").options;
- var header = $.data(jq, "cmsXDataTable").header;
- var table = $.data(jq, "cmsXDataTable").table;
- var totalWidth = $.data(jq, "cmsXDataTable").totalWidth;
- var columnList = $.data(jq, "cmsXDataTable").columnList;
- var pagerPanel = $.data(jq, "cmsXDataTable").pagerPanel;
- var btnPagerFirst = $.data(jq, "cmsXDataTable").btnPagerFirst;
- var btnPagerPrev = $.data(jq, "cmsXDataTable").btnPagerPrev;
- var btnPagerNext = $.data(jq, "cmsXDataTable").btnPagerNext;
- var btnPagerLast = $.data(jq, "cmsXDataTable").btnPagerLast;
- var tableid = table.closest(".easyui-cmsXDataTable").attr("id");
- var tableDataHidden = $("#" + tableid + "_datajson");
- var treeColumn;
- $.each(columnList, function () {
- if (this.columnType == 'tree') {
- treeColumn = this;
- return false;
- }
- });
- if (treeColumn) {
- var tmpRows = new Array();
- _orderDataForTree(data.rows, treeColumn.field, treeColumn.parentIDField, treeColumn.orderByField, tmpRows);
- data.rows = tmpRows;
- }
- if (opts.pagerType == 0 || !opts.data || isLoadAll) {
- //这两句的顺序可不能错,remove的时候原来会触发textbox的propertychange事件,
- //因为暂时没办法阻止这个触发,只好让它触发够了再重新赋值……
- table.find("tr.row").remove();
- opts.data = data;
- } else {
- for (var i = 0; i < data.rows.length; i++) {
- opts.data.rows.push(data.rows[i]);
- }
- }
- if (opts.isPostBack)
- tableDataHidden.val(JSON.stringify(opts.data));
- var deep = 0;
- $.each(data.rows, function (rowIndex) {
- var rowData = this;
- var tdHtmlList = [];
- var realRowIndex = rowIndex;
- if (opts.pagerType == 1 && opts.pagination) {
- realRowIndex += (opts.pageNumber - 1) * opts.pageSize;
- }
- //add by heyw,增加扩展行开始
- //正常行增加一列,并带有展开按钮
- if (opts.hasSubRow == true) {
- if (opts.expandOnLoad == true) {
- tdHtmlList.push("".concat('<td style="width: 20px; line-height: 16px;"><div class="subrow-expander tree-expanded" style="cursor: pointer;" rowIndex="' + realRowIndex + '"></div></td>'));
- }
- else {
- tdHtmlList.push("".concat('<td style="width: 20px; line-height: 16px;"><div class="subrow-expander tree-collapsed" style="cursor: pointer;" rowIndex="' + realRowIndex + '"></div></td>'));
- }
- }
- //add by heyw,增加扩展行结束
- $.each(columnList, function () {
- var columnOpts = this;
- var tdStyle = "width:" + parseInt(columnOpts.width) + "px;";
- if (opts.hasSubRow == true && columnOpts.field == "") { return; }
- if (columnOpts.hidden) {
- tdStyle = "display:none;";
- }
- if (columnOpts.columnType == "checkbox") {
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '"><input type="checkbox" value="', eval("rowData." + columnOpts.field), '"'));
- if (rowData[columnOpts.checkfield]) {
- tdHtmlList.push("".concat(' checked '));
- }
- tdHtmlList.push("".concat('/></td>'));
- var selectAll = $(header.find('.header th').get(columnOpts.columnIndex)).find('input[type="checkbox"]');
- selectAll.removeAttr("checked");
- } else if (columnOpts.columnType == "radiobox") {
- var controlName = columnOpts.field;
- if (columnOpts.customName && columnOpts.customName != "") {
- controlName = columnOpts.customName;
- }
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '"><input type="radio" name="', controlName, '_', realRowIndex.toString(), '" value="', columnOpts.radioValue.toString(), '"'));
- if (columnOpts.radioValue == eval("rowData." + columnOpts.field)) {
- tdHtmlList.push("".concat(' checked="checked" '));
- }
- tdHtmlList.push("".concat('/></td>'));
- } else if (columnOpts.columnType == "checkbutton") {
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '"><input type="checkbox" name="', columnOpts.field, '_', realRowIndex.toString(), '"'));
- if (eval("rowData." + columnOpts.field)) {
- tdHtmlList.push("".concat(' checked="checked" '));
- }
- tdHtmlList.push("".concat('/></td>'));
- } else if (columnOpts.columnType == "imagebutton") {
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '"><a href="#this"'));
- if (columnOpts.handle) {
- tdHtmlList.push("".concat(' onclick="return ', columnOpts.handle, '(', rowIndex, ",$(this).closest('.easyui-cmsXDataTable').cmsXDataTable('getRows')[" + rowIndex + '])"'));
- }
- tdHtmlList.push("".concat('><img src="', eval("rowData." + columnOpts.field), '" style="border: 0px; width:', columnOpts.imageWidth, '; height:', columnOpts.itemHeight, '" />'));
- tdHtmlList.push("".concat('</a></td>'));
- } else if (columnOpts.columnType == "textbox" || columnOpts.columnType == "triggerbox") {
- var formatterValue = columnOpts.formatter.call(jq, eval("rowData." + columnOpts.field), rowData, rowIndex, columnOpts.overflowlength);
- if (formatterValue != 0) {
- formatterValue = formatterValue || "";
- }
- if (!columnOpts.isMultiline) {
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '"><input type="text" style="width: 98%;" value="', formatterValue, '" /></td>'));
- } else {
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '"><textarea rows="3" style="width: 98%;">', formatterValue, '</textarea></td>'));
- }
- } else if (columnOpts.columnType == "dropdownlist" || columnOpts.columnType == "dictionary") {
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '">'));
- tdHtmlList.push("".concat('<select id="', tableid, '_', columnOpts.fieldname, '_', columnOpts.columnIndex, '" name="', tableid, '_', columnOpts.fieldname, '_', columnOpts.columnIndex, '" style="width: 98%;"/>'));
- tdHtmlList.push("".concat('</td>'));
- } else if (columnOpts.columnType == "autocomplete") {
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '">'));
- tdHtmlList.push("".concat('<input type="text" id="', tableid, '_', columnOpts.fieldname, '_', columnOpts.columnIndex, '_text" name="', tableid, '_', columnOpts.fieldname, '_', columnOpts.columnIndex, '_text" style="width: 98%;"/>'));
- tdHtmlList.push("".concat('<input type="hidden" id="', tableid, '_', columnOpts.fieldname, '_', columnOpts.columnIndex, '" name="', tableid, '_', columnOpts.fieldname, '_', columnOpts.columnIndex, '" value="', eval("rowData." + columnOpts.field), '" />'));
- tdHtmlList.push("".concat('</td>'));
- } else if (columnOpts.columnType == "tree") {
- var fullID = _getFullID(data.rows, rowData, columnOpts.parentIDField, columnOpts.field);
- deep = fullID.split('.').length - 1;
- tdHtmlList.push("".concat('<td fullTreeID="', fullID, '" columnIndex="', columnOpts.columnIndex, '" align="left" style="', tdStyle, '">', _treeFormatter(columnOpts, rowData, data.rows[rowIndex + 1], deep), ' </td>'));
- } else {
- var formatterValue = columnOpts.formatter.call(jq, eval("rowData." + columnOpts.field), rowData, rowIndex, columnOpts.overflowlength, columnOpts.emptyText);
- if (formatterValue != 0) {
- formatterValue = formatterValue || columnOpts.defaultValue;
- }
- var titleValue;
- if (!columnOpts.columnType) {
- titleValue = eval("rowData." + columnOpts.field) == null ? '' : columnOpts.formatter.call(jq, eval("rowData." + columnOpts.field), rowData, rowIndex, 0, columnOpts.emptyText);
- if (titleValue != 0) {
- titleValue = titleValue || columnOpts.defaultValue;
- }
- } else {
- titleValue = eval("rowData." + columnOpts.field) == null ? '' : eval("rowData." + columnOpts.field);
- }
- if (titleValue.toString().indexOf('<') >= 0) {
- titleValue = eval("rowData." + columnOpts.field) == null ? '' : eval("rowData." + columnOpts.field);
- }
- tdHtmlList.push("".concat('<td columnIndex="', columnOpts.columnIndex, '" style="', tdStyle, '" title="', titleValue, '">', formatterValue, ' </td>'));
- }
- });
- var rowStyle = opts.rowStyle.call(jq, realRowIndex, rowData);
- var highlightProp = _getHighlightProp(jq, rowIndex);
- if (realRowIndex % 2 == 0) {
- $(''.concat('<tr class="row row2"' + highlightProp + ' style="' + rowStyle + '" xRowIndex="', realRowIndex, '">', tdHtmlList.join(""), '</tr>')).appendTo(table);
- } else {
- $(''.concat('<tr class="row"' + highlightProp + ' style="' + rowStyle + '" xRowIndex="', realRowIndex, '">', tdHtmlList.join(""), '</tr>')).appendTo(table);
- }
- //add by heyw,增加扩展行开始
- //填写扩展行内容
- if (opts.hasSubRow == true) {
- var subRowHtml = opts.subRowFomatter(rowData, rowIndex);
- if (opts.expandOnLoad == true) {
- $(''.concat('<tr class="row" style="' + rowStyle + '"' + highlightProp + ' rowIndex="', realRowIndex, '"><td colspan=' + columnList.length + '>', subRowHtml, '</td></tr>')).appendTo(table);
- }
- else {
- $(''.concat('<tr class="row" style="' + rowStyle + '"' + highlightProp + ' style="display: none;" rowIndex="', realRowIndex, '"><td colspan=' + columnList.length + '>', subRowHtml, '</td></tr>')).appendTo(table);
- }
- }
- //add by heyw,增加扩展行结束
- });
- //add by heyw,增加扩展行开始
- //绑定展开按钮事件
- table.find("tr.row>td>div.subrow-expander").each(function () {
- this.onclick = function () {
- var subRow = table.find("tr.row[rowIndex=" + $(this).attr("rowIndex") + "]");
- var oldDisplay = subRow.css("display");
- if (oldDisplay == "none") {
- subRow.css("display", "");
- $(this).attr("class", "tree-expanded");
- }
- else {
- subRow.css("display", "none");
- $(this).attr("class", "tree-collapsed");
- }
- }
- });
- if (opts.isMouseOverHighlight) {
- table.find("tr.row").mouseover(function() {
- $(this).css("background-color", opts.rowHighlightColor);
- $(this).find("td").css("background-color", opts.rowHighlightColor);
- $(this).bind("mouseout.hightlight", function() {
- $(this).css("background-color", "");
- $(this).find("td").css("background-color", "");
- $(this).unbind("mouseout.hightlight");
- });
- });
- }
- if (opts.checkOnSelect) {
- var checkboxColumnIndexList = $.map(
- $.grep(columnList, function (x){ return x.columnType == "checkbox"; }),
- function(x) { return x.columnIndex; });
- table.find('tr.row').click(function() {
- if (event.srcElement.type == "checkbox") return;
- for (var i = 0; i < checkboxColumnIndexList.length; i ++) {
- var checkboxList = $(this).find('td[columnIndex=' + checkboxColumnIndexList[i] + '] input[type="checkbox"]');
- for (var j = 0; j < checkboxList.length; j ++) {
- checkbox = $(checkboxList[j]);
- var isChecked = !checkbox.attr("checked");
- checkbox.attr("checked", isChecked);
- if (isChecked) {
- $(this).addClass("row_selected");
- } else {
- $(this).removeClass("row_selected");
- }
- }
- }
- });
- }
- if (opts.onClickRow) {
- table.find('tr.row').css("cursor", "pointer").click(function () {
- var grid = $(this).parents('.easyui-cmsXDataTable:first');
- var gridOpts = $.data(grid[0], "cmsXDataTable").options;
- var gridData = gridOpts.data;
- var rowIndex = parseInt($(this).attr("xRowIndex"));
- var rowData = gridData.rows[rowIndex];
- opts.onClickRow.call(grid, rowIndex, rowData);
- });
- }
- if (opts.onDblClickRow) {
- table.find('tr.row').css("cursor", "pointer").dblclick(function () {
- var grid = $(this).parents('.easyui-cmsXDataTable:first');
- var gridOpts = $.data(grid[0], "cmsXDataTable").options;
- var gridData = gridOpts.data;
- var rowIndex = parseInt($(this).attr("xRowIndex"));
- var rowData = gridData.rows[rowIndex];
- opts.onDblClickRow.call(grid, rowIndex, rowData);
- });
- }
- //add by heyw,增加扩展行结束
- //add by heyw,创建自定义控件开始
- _createTableControls(jq);
- //add by heyw,创建自定义控件结束
- opts.totalPage = Math.ceil(opts.data.total / opts.pageSize);
- if (opts.pagerType == 0 && opts.pagination) {
- btnPagerFirst.removeClass("l-btn-disabled");
- btnPagerPrev.removeClass("l-btn-disabled");
- btnPagerNext.removeClass("l-btn-disabled");
- btnPagerLast.removeClass("l-btn-disabled");
- if (opts.pageNumber == 1) {
- btnPagerFirst.addClass("l-btn-disabled");
- btnPagerPrev.addClass("l-btn-disabled");
- }
- if (opts.pageNumber >= opts.totalPage) {
- btnPagerNext.addClass("l-btn-disabled");
- btnPagerLast.addClass("l-btn-disabled");
- }
- pagerPanel.find("input.xDataTablePanel_pager-num").val(opts.pageNumber);
- pagerPanel.find(".xDataTablePanel_pager-totalInfo").html("共" + opts.totalPage + "页");
- pagerPanel.find(".xDataTablePanel_pager_info").html("显示" + ((opts.pageNumber - 1) * opts.pageSize + 1) + "到" + ((opts.pageNumber - 1) * opts.pageSize + data.rows.length) + ",共" + data.total + "条记录");
- } else {
- pagerPanel.find(".xDataTablePanel_pager_Simp").removeClass("l-btn-disabled");
- if (opts.pageNumber >= opts.totalPage) {
- pagerPanel.find(".xDataTablePanel_pager_Simp").addClass("l-btn-disabled");
- }
- }
- if (typeof (opts.onLoadSuccess) == "function") {
- opts.onLoadSuccess.call(jq, data);
- }
- if (opts.isAutoHeight) {
- if (table.parent().height() < table.height()) {
- table.parent().height(table.height());
- }
- if (table[0].offsetWidth > table.parent()[0].offsetWidth) {
- table.parent().height(table.height() + 16);
- }
- }
-
- var firstRow = table.find("tr");
- if (firstRow.length > 0) { //一行都没有一般就不会错位
- header.find("tr.header>th").each(function(i, v) {
- var width = $($(firstRow[0]).find("td")[i]).width();
- $(this).width(width);
- });
- }
- };
- var _getFullID = function (dataRows, rowData, parentField, idField) {
- var id = rowData[idField];
- if (!rowData[parentField]) return id;
- var parentData = $.grep(dataRows, function (v) { return v[idField] == rowData[parentField]; })[0];
- return id + "." + _getFullID(dataRows, parentData, parentField, idField);
- };
- var _generalComparer = function (a, b) {
- if (a == null && b == null) {
- return 0;
- }
- else if (a == null) {
- return -1;
- }
- else if (b == null) {
- return 1;
- }
- else if (a == b) {
- return 0;
- }
- else if (a > b) {
- return 1;
- }
- else {
- return -1;
- }
- };
- var _orderDataForTree = function (dataRows, idField, parentField, orderField, result) {
- var topRows = $.grep(dataRows, function (v) { return v[parentField] == null; })
- .sort(function (a, b) { return _generalComparer(a[orderField], b[orderField]); });
- $.each(topRows, function (i, v) {
- result.push(v);
- _pushChild(dataRows, v, idField, parentField, orderField, result);
- })
- };
- var _pushChild = function (dataRows, value, idField, parentField, orderField, result) {
- var childRows = $.grep(dataRows, function (v) { return v[parentField] == value[idField]; })
- .sort(function (a, b) { return _generalComparer(a[orderField], b[orderField]); });
- $.each(childRows, function (i, v) {
- result.push(v);
- _pushChild(dataRows, v, idField, parentField, orderField, result);
- });
- };
- var _treeFormatter = function (columnOpts, rowData, nextRowData, deep) {
- var html = new Array();
- var i;
- for (i = 0; i < deep; i++) {
- html.push('<span class="tree-indent"></span>');
- }
- //有无子集
- if (nextRowData && eval("nextRowData." + columnOpts.parentIDField) == eval("rowData." + columnOpts.field)) {
- html.push('<span class="tree-hit tree-expanded"></span>');
- }
- else {
- html.push('<span class="tree-indent"></span>');
- }
- html.push('<span class="tree-icon tree-folder"></span>');
- html.push('<span class="tree-title">' + rowData[columnOpts.textField] + '</span>');
- return html.join('');
- };
- var _getRealRowIndex = function (opts, rowIndex) {
- var realRowIndex = rowIndex;
- if (opts.pagerType == 1 && opts.pagination) {
- realRowIndex += (opts.pageNumber - 1) * opts.pageSize;
- }
- return realRowIndex;
- }
- var _createTableControls = function (jq) {
- var opts = $.data(jq, "cmsXDataTable").options;
- var table = $.data(jq, "cmsXDataTable").table;
- var columnList = $.data(jq, "cmsXDataTable").columnList;
- $.each(columnList, function () {
- var columnOpts = this;
- var columnIndex = columnOpts.columnIndex;
- var isEditableColumn = true;
- if (columnOpts.columnType == "autocomplete") {
- _createAutoCompleteControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "textbox" && !columnOpts.isMultiline) {
- _createTextBoxControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "textbox" && columnOpts.isMultiline) {
- _createMultilineControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "triggerbox") {
- _createTriggerBoxControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "radiobox") {
- _createRadioBoxControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "checkbutton") {
- _createCheckButtonControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "dropdownlist") {
- _createDropdownControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "dictionary") {
- _createDictionaryControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "tree") {
- isEditableColumn = false;
- _createTreeControl(columnOpts, table);
- }
- else if (columnOpts.columnType == "linkbutton" || columnOpts.columnType == "imagebutton") {
- var enableFieldName = columnOpts.enableFieldName;
- if (enableFieldName && enableFieldName != "") {
- $.each(opts.data.rows, function (index, rowData) {
- var realRowIndex = _getRealRowIndex(opts, index);
- var tableRow = table.find("tr.row[xRowIndex=" + realRowIndex.toString() + "]");
- if (!eval("rowData." + enableFieldName)) {
- //$(tableRow.find("td")[columnIndex]).html($(tableRow.find("td")[columnIndex]).text());
- $(tableRow.find("td")[columnIndex]).find('*').attr("disabled", "disabled");
- $(tableRow.find("td")[columnIndex]).find('*').addClass("disabledLink");
- }
- });
- }
- var visibleFieldName = columnOpts.visibleFieldName;
- if (visibleFieldName && visibleFieldName != "") {
- $.each(opts.data.rows, function (index, rowData) {
- var realRowIndex = _getRealRowIndex(opts, index);
- var tableRow = table.find("tr.row[xRowIndex=" + realRowIndex.toString() + "]");
- if (!eval("rowData." + visibleFieldName)) {
- $(tableRow.find("td")[columnIndex]).html(" ");
- }
- });
- }
- isEditableColumn = false;
- }
- else {
- isEditableColumn = false;
- }
- if (isEditableColumn) {
- var enableFieldName = columnOpts.enableFieldName;
- if (enableFieldName && enableFieldName != "") {
- $.each(opts.data.rows, function (index, rowData) {
- var realRowIndex = _getRealRowIndex(opts, index);
- var tableRow = table.find("tr.row[xRowIndex=" + realRowIndex.toString() + "]");
- if (eval("!rowData." + enableFieldName)) {
- $(tableRow.find("td")[columnIndex]).children().attr("disabled", "disabled");
- }
- });
- }
- var visibleFieldName = columnOpts.visibleFieldName;
- if (visibleFieldName && visibleFieldName != "") {
- $.each(opts.data.rows, function (index, rowData) {
- var realRowIndex = _getRealRowIndex(opts, index);
- var tableRow = table.find("tr.row[xRowIndex=" + realRowIndex.toString() + "]");
- if (eval("!rowData." + visibleFieldName)) {
- $(tableRow.find("td")[columnIndex]).children().css("display", "none");
- }
- });
- }
- }
- });
- };
- var _createTreeControl = function (columnOpts, table) {
- $(table).find(".tree-hit").each(function () {
- $(this).mouseover(function (e) {
- if ($(e.target).hasClass("tree-expanded"))
- $(e.target).addClass("tree-expanded-hover");
- else
- $(e.target).addClass("tree-collapsed-hover");
- });
- $(this).mouseout(function (e) {
- if ($(e.target).hasClass("tree-expanded-hover"))
- $(e.target).removeClass("tree-expanded-hover");
- else
- $(e.target).removeClass("tree-collapsed-hover");
- });
- $(this).click(function (e) {
- if ($(e.target).hasClass("tree-expanded-hover")) {
- $(e.target).removeClass("tree-expanded");
- $(e.target).removeClass("tree-expanded-hover");
- $(e.target).addClass("tree-collapsed");
- $(e.target).addClass("tree-collapsed-hover");
- }
- else {
- $(e.target).removeClass("tree-collapsed");
- $(e.target).removeClass("tree-collapsed-hover");
- $(e.target).addClass("tree-expanded");
- $(e.target).addClass("tree-expanded-hover");
- }
- var childRows = $(table).find("td[fullTreeID$='" + $(e.target).parent().attr("fullTreeID") + "']");
- childRows = $.grep(childRows, function (v) {
- return $(v).attr("fullTreeID") != $(e.target).parent().attr("fullTreeID");
- });
- $.each(childRows, function () {
- if ($(this).parent().css("display") == "none") {
- $(this).parent().css("display", "");
- } else {
- $(this).parent().css("display", "none");
- }
- });
- });
- });
- };
- var _createTextBoxControl = function (columnOpts, table) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true;
- var rowIndex = $(this).attr("xRowIndex");
- var textControl = $($(this).find("td")[columnOpts.columnIndex]).find('input');
- textControl.on('input propertychange', function (e) {
- var textValue;
- if (!columnOpts.validateOption) {
- textValue = $(this).val();
- } else {
- switch (columnOpts.validateOption.validType) {
- case "onlyMoney" :
- case "onlyDiscount" :
- case "onlyNumber" :
- if (isNaN($(this).val())) {
- textValue = null;
- } else {
- textValue = parseFloat($(this).val());
- }
- break;
- default :
- textValue = $(this).val();
- break;
- }
- }
- _changeDataJson(table, rowIndex, columnOpts.field, textValue, columnOpts);
- });
- if (columnOpts.validateOption) {
- textControl.validatebox(columnOpts.validateOption);
- }
- });
- };
- var _createMultilineControl = function (columnOpts, table) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true;
- var rowIndex = $(this).attr("xRowIndex");
- var textControl = $($(this).find("td")[columnOpts.columnIndex]).find('textarea');
- textControl.on('textarea propertychange', function (e) {
- var textValue;
- if (!columnOpts.validateOption) {
- textValue = $(this).val();
- } else {
- switch (columnOpts.validateOption.validType) {
- case "onlyMoney" :
- case "onlyDiscount" :
- case "onlyNumber" :
- if (isNaN($(this).val())) {
- textValue = null;
- } else {
- textValue = parseFloat($(this).val());
- }
- break;
- default :
- textValue = $(this).val();
- break;
- }
- }
- _changeDataJson(table, rowIndex, columnOpts.field, textValue, columnOpts);
- });
- if (columnOpts.validateOption) {
- textControl.validatebox(columnOpts.validateOption);
- }
- });
- };
- var _createTriggerBoxControl = function (columnOpts, table) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true;
- var rowIndex = $(this).attr("xRowIndex");
- var textControl = $($(this).find("td")[columnOpts.columnIndex]).find('input');
- var jq = table.closest(".easyui-cmsXDataTable")[0];
- var opts = $.data(jq, "cmsXDataTable").options;
- textControl.triggerbox({
- valueField: columnOpts.targetField,
- textField: columnOpts.targetTextField,
- separator: ",",
- editable: true,
- postData: {},
- change: function () {
- var selectedData = $(this).triggerbox("getData");
- if (selectedData.length > 0) {
- var value;
- if (Object.prototype.toString.call(opts.data.rows[rowIndex][columnOpts.field]) === "[object Array]") {
- value = selectedData;
- } else {
- value = $.map(selectedData, function(x) { return x[columnOpts.targetField];}).join(',');
- }
- var text = $.map(selectedData, function(x) { return x[columnOpts.targetTextField];}).join(',');
- _changeDataJson(table, rowIndex, columnOpts.field, value, columnOpts);
- _changeDataJson(table, rowIndex, columnOpts.textfield, text, columnOpts);
- } else {
- if (Object.prototype.toString.call(opts.data.rows[rowIndex][columnOpts.field]) === "[object Array]") {
- _changeDataJson(table, rowIndex, columnOpts.field, [], columnOpts);
- } else {
- _changeDataJson(table, rowIndex, columnOpts.field, null, columnOpts);
- }
- _changeDataJson(table, rowIndex, columnOpts.textfield, null, columnOpts);
- }
- },
- onSearch: columnOpts.triggerHandle
- });
- var newArray = new Array();
- var newObj = new Object();
- if (Object.prototype.toString.call(opts.data.rows[rowIndex][columnOpts.field]) === "[object Array]") {
- newArray = opts.data.rows[rowIndex][columnOpts.field];
- } else {
- newObj[columnOpts.targetField] = opts.data.rows[rowIndex][columnOpts.field];
- newObj[columnOpts.targetTextField] = opts.data.rows[rowIndex][columnOpts.textfield];
- newArray.push(newObj);
- }
- textControl.triggerbox('setValue', newArray);
- });
- }
- var _createRadioBoxControl = function (columnOpts, table) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true;
- var rowIndex = $(this).attr("xRowIndex");
- var radioControl = $($(this).find("td")[columnOpts.columnIndex]).find('input');
- radioControl.click(function () {
- _changeDataJson(table, rowIndex, columnOpts.field, $(this).val(), columnOpts);
- });
- });
- };
- var _createCheckButtonControl = function (columnOpts, table) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true;
- var rowIndex = $(this).attr("xRowIndex");
- var checkButtonControl = $($(this).find("td")[columnOpts.columnIndex]).find('input');
- checkButtonControl.click(function () {
- _changeDataJson(table, rowIndex, columnOpts.field, $(this).prop("checked"), columnOpts);
- });
- });
- };
- var _createDropdownControl = function (columnOpts, table) {
- var jq = table.closest(".easyui-cmsXDataTable")[0];
- var opts = $.data(jq, "cmsXDataTable").options;
- $.ajax({
- // try to leverage ajaxQueue plugin to abort previous requests
- mode: "abort",
- // limit abortion to this input
- dataType: "json",
- url: columnOpts.url,
- data: $.extend({
- bindType: 0
- }, {}),
- success: function (data) {
- if (data && data.length) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true;
- var rowIndex = $(this).attr("xRowIndex");
- var selectControl = $($(this).find("td")[columnOpts.columnIndex]).find('select');
- selectControl.empty();
- $("<option value='-1'>---请选择---</option>").appendTo(selectControl);
- $.each(data, function () {
- if (this[columnOpts.valueField] == eval("opts.data.rows[rowIndex]." + columnOpts.fieldname)) {
- $("<option value='" + this[columnOpts.valueField] + "' selected>" + this[columnOpts.textField] + "</option>").appendTo(selectControl);
- } else {
- $("<option value='" + this[columnOpts.valueField] + "'>" + this[columnOpts.textField] + "</option>").appendTo(selectControl);
- }
- });
-
- $(selectControl).bind("click", function () {
- var selectedValue = $(this).val();
- if (selectedValue == "-1") selectedValue = null;
- _changeDataJson(table, rowIndex, columnOpts.fieldname, selectedValue, columnOpts);
- });
- if (columnOpts.validateOption) {
- $(selectControl).validatebox(columnOpts.validateOption);
- }
- });
- }
- }
- });
- };
- var _createDictionaryControl = function (columnOpts, table) {
- var jq = table.closest(".easyui-cmsXDataTable")[0];
- var opts = $.data(jq, "cmsXDataTable").options;
- var dictionaryCode = columnOpts.dictionaryCode;
- if (dictionaryCode && dictionaryCode != "") {
- $.post(CMS_SystemConfig.VirtualDirectoryPath + '/Common/DictionaryDropDown', { bindType: 0, dictionaryCode: dictionaryCode }, function (dictionaryData) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true; //跳过标题行
- var rowIndex = $(this).attr("xRowIndex");
- var selectControl = $($(this).find("td")[columnOpts.columnIndex]).find('select');
- selectControl.empty();
- $.each(dictionaryData, function () {
- if (this.Value == opts.data.rows[rowIndex][columnOpts.fieldname]) {
- $("<option value='" + this.Value + "' selected>" + this.Text + "</option>").appendTo(selectControl);
- } else {
- $("<option value='" + this.Value + "'>" + this.Text + "</option>").appendTo(selectControl);
- }
- });
- $(selectControl).bind("click", function () {
- var selectedValue = $(this).val();
- if (selectedValue == "-1") selectedValue = null;
- _changeDataJson(table, rowIndex, columnOpts.fieldname, selectedValue, columnOpts);
- });
- if (columnOpts.validateOption) {
- $(selectControl).validatebox(columnOpts.validateOption);
- }
- });
- });
- }
- };
- var _createAutoCompleteControl = function (columnOpts, table) {
- var top = 10;
- //这里开始要修改成一次过读出数据……
- $.ajax({
- // try to leverage ajaxQueue plugin to abort previous requests
- mode: "abort",
- // limit abortion to this input
- dataType: "json",
- url: columnOpts.url,
- data: $.extend({
- q: "",
- limit: 99999
- }, {}),
- success: function (data) {
- if (data && data.length) {
- $(table).find("tr").each(function () {
- if ($(this).find("th").length > 0) return true;
- var rowIndex = $(this).attr("xRowIndex");
- var textControl = $($(this).find("td")[columnOpts.columnIndex]).find('input[type="text"]');
- var valueBox = $($(this).find("td")[columnOpts.columnIndex]).find('input[type="hidden"]');
- $.each(data, function () {
- if (this[columnOpts.valueField].toString() == $(valueBox).val()) {
- $(textControl).val(this[columnOpts.textField]);
- }
- });
- $(textControl).autocomplete(data, {
- max: top,
- minChars: 1,
- width: columnOpts.width,
- scrollHeight: columnOpts.scrollHeight,
- matchContains: columnOpts.matchContains,
- mustMatch: columnOpts.mustMatch,
- cacheLength: 99999, //1- 无缓存
- autoFill: columnOpts.autoFill,
- dataType: 'json',
- parse: function (data) {
- var parsed = [];
- for (var i = 0; i < data.length; i++) {
- parsed[parsed.length] = {
- data: data[i],
- value: data[i][columnOpts.valueField].toString(),
- result: data[i][columnOpts.textField]
- };
- }
- return parsed;
- },
- formatItem: columnOpts.formatter,
- formatMatch: function (row, i, max) {
- return row[columnOpts.textField];
- },
- formatResult: function (row) {
- $(valueBox).val(row[columnOpts.valueField]);
- _changeDataJson(table, rowIndex, columnOpts.fieldname, row[columnOpts.valueField], columnOpts);
- return row[columnOpts.textField];
- }
- });
- if (columnOpts.validateOption) {
- $(textControl).validatebox(columnOpts.validateOption);
- }
- });
- }
- }
- });
- }
- var _changeDataJson = function (table, rowIndex, fieldName, value, columnOpts) {
- var jq = table.closest(".easyui-cmsXDataTable")[0];
- var config = $.data(jq, "cmsXDataTable");
- var opts = config.options;
- if (opts.data.rows.length <= rowIndex) return;
- eval("opts.data.rows[rowIndex]." + fieldName + " = value");
- //$.data(jq, "cmsXDataTable", config);
- if (!opts.isPostBack) return;
- var tableid = table.closest(".easyui-cmsXDataTable").attr("id");
- var tableDataHidden = $("#" + tableid + "_datajson");
- var data = JSON.parse($(tableDataHidden).val());
-
- eval("data.rows[rowIndex]." + fieldName + " = value");
- $(tableDataHidden).val(JSON.stringify(data));
- if (columnOpts) {
- if (columnOpts.onChanged) columnOpts.onChanged.call(columnOpts, rowIndex, data.rows[rowIndex]);
- }
- };
- var _getRowDataByObj = function (jq, obj) {
- var rowIndex = parseInt($(obj).closest("tr").attr("xRowIndex"));
- var opts = $.data(jq, "cmsXDataTable").options;
- var data = opts.data;
- return data.rows[rowIndex];
- };
- var _getRows = function (jq) {
- var opts = $.data(jq, "cmsXDataTable").options;
- if (!opts.isPostBack) {
- if (opts.data) {
- return opts.data.rows;
- } else {
- return [];
- }
- }
- else {
- var tableid = $(jq).attr("id");
- var tableDataHidden = $("#" + tableid + "_datajson");
- if (tableDataHidden.val() != "") {
- return JSON.parse(tableDataHidden.val()).rows;
- } else {
- return [];
- }
- }
- };
- var _getTotal = function (jq) {
- var opts = $.data(jq, "cmsXDataTable").options;
- return opts.data.total;
- };
- var _getSelections = function (jq) {
- var opts = $.data(jq, "cmsXDataTable").options;
- var table = $.data(jq, "cmsXDataTable").table;
- var selectionsList = new Array();
- table.find("tr.row_selected").each(function () {
- selectionsList.push(opts.data.rows[$(this).attr("xRowIndex")]);
- });
- return selectionsList;
- };
- var _clearSelections = function (jq) {
- var opts = $.data(jq, "cmsXDataTable").options;
- var table = $.data(jq, "cmsXDataTable").table;
- var columnList = $.data(jq, "cmsXDataTable").columnList;
- var checkboxIndex = 0;
- $.each(columnList, function () {
- if (this.columnType == "checkbox") {
- checkboxIndex = this.columnIndex;
- return false;
- }
- });
- table.find("tr.row_selected").removeClass("row_selected").each(function () {
- $(this).find(">td[columnIndex='" + checkboxIndex + "']>input[type='checkbox']").attr("checked", false);
- });
- };
- var _deleteSubRowItem = function (jq, delData) {
- var tableSettings = $.data(jq, "cmsXDataTable");
- var table = $.data(jq, "cmsXDataTable").table;
- var opts = tableSettings.options;
- var data = opts.data;
- var rowIndex = delData.rowIndex;
- var delValue = delData.value;
- var listElement = delData.listElement;
- var valueElement = delData.valueElement;
- //debugger;
- if (opts.onSubRowItemDelete) {
- var deleted = $.grep(data.rows[rowIndex][listElement], function (v, i) {
- var elementTree = valueElement.split('.');
- var firstElement = elementTree[0];
- elementTree.splice(0, 1);
- var lastElement = elementTree.join('.');
- var expression = 'new Object(v["' + firstElement + '"])';
- if (lastElement != "") {
- expression += '.' + lastElement;
- }
- return eval(expression) == delValue;
- });
- opts.onSubRowItemDelete(deleted[0]);
- }
- var afterDel = $.grep(data.rows[rowIndex][listElement], function (v, i) {
- var elementTree = valueElement.split('.');
- var firstElement = elementTree[0];
- elementTree.splice(0, 1);
- var lastElement = elementTree.join('.');
- var expression = 'new Object(v["' + firstElement + '"])';
- if (lastElement != "") {
- expression += '.' + lastElement;
- }
- return eval(expression) != delValue;
- });
- data.rows[rowIndex][listElement] = afterDel;
- tableSettings.options.data = data;
- $.data(jq, "cmsXDataTable", tableSettings);
- if (opts.isPostBack) {
- var tableid = table.closest(".easyui-cmsXDataTable").attr("id");
- var tableDataHidden = $("#" + tableid + "_datajson");
- $(tableDataHidden).val(JSON.stringify(data));
- }
- tableSettings.table.find("tr.row[rowIndex=" + rowIndex + "]>td").html(opts.subRowFomatter(data.rows[rowIndex], rowIndex));
- }
- var _clearOrderByAsc = function (jq) {
- var headerTable = $(jq).find('.xDataTableHeader');
- $.each(headerTable.find('th div a'), function (i, v) {
- $(v).attr('asc', '1');
- });
- }
- $.fn.cmsXDataTable = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsXDataTable.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsXDataTable(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsXDataTable");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsXDataTable", { options: $.extend({}, $.fn.cmsXDataTable.defaults, $.fn.cmsXDataTable.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsXDataTable", $.extend({}, cacheData, initCacheData));
- }
- if (cacheData.options.autoLoad) {
- if (cacheData.data && cacheData.data.length > 0) {
- _loadData(this, cacheData.data, false);
- } else {
- var conditionControls = $.grep($("[data-condition='" + this.id + "']"), function(x) {
- var opts = $.parser.parseOptions(x, []);
- return !$(x).closest("ul").attr("dynamicWhere") && opts.value && opts.value != "" && opts.value != "-1";
- });
- var isReady = true;
- $.each(conditionControls, function (i, x) {
- var isCombobox = $(x).hasClass('easyui-combobox');
- var isComboGrid = $(x).hasClass('easyui-combogridX');
- var comboboxData = $.data(x, 'combobox');
- var combogridData = $.data(x, 'combogridX');
- if (!isCombobox && !isComboGrid) {
- return true;
- }
- if (isCombobox && !comboboxData) {
- isReady = false;
- return false;
- }
- if (isComboGrid && !combogridData) {
- isReady = false;
- return false;
- }
- if (comboboxData) {
- if (comboboxData.options.value && comboboxData.options.value != ''
- && comboboxData.options.value != '-1' && $(x).next().find(".combo-value").val() == "") {
- isReady = false;
- return false;
- } else {
- return true;
- }
- } else {
- if (combogridData.options.value && combogridData.options.value != '' && combogridData.options.value != -1
- && combogridData.options.text != '' && $(x).attr("loaded") != "true") {
- isReady = false;
- return false;
- } else {
- return true;
- }
- }
- });
- if (isReady && $(this).length > 0 && $.data(this, "cmsXDataTable")) {
- var opts = $.data(this, "cmsXDataTable").options;
- opts.pageNumber = 1;
- _load(this, $.getDataGridParams(this.id), false);
- }
- }
- }
- });
- };
- $.fn.cmsXDataTable.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsXDataTable").options;
- return opts;
- },
- load: function (jq, formData) {
- jq.each(function () {
- var conditionControls = $.grep($("[data-condition='" + this.id + "']"), function(x) {
- var opts = $.parser.parseOptions(x, []);
- return !$(x).closest("ul").attr("dynamicWhere") && opts.value && opts.value != "" && opts.value != "-1";
- });
- var isReady = true;
- $.each(conditionControls, function (i, x) {
- var isCombobox = $(x).hasClass('easyui-combobox');
- var isComboGrid = $(x).hasClass('easyui-combogridX');
- var comboboxData = $.data(x, 'combobox');
- var combogridData = $.data(x, 'combogridX');
- if (!isCombobox && !isComboGrid) {
- return true;
- }
- if (isCombobox && !comboboxData) {
- isReady = false;
- return false;
- }
- if (isComboGrid && !combogridData) {
- isReady = false;
- return false;
- }
- if (comboboxData) {
- if (comboboxData.options.value && comboboxData.options.value != ''
- && comboboxData.options.value != '-1' && $(x).next().find(".combo-value").val() == "") {
- isReady = false;
- return false;
- } else {
- return true;
- }
- } else {
- if (combogridData.options.value && combogridData.options.value != '' && combogridData.options.value != -1
- && combogridData.options.text != '' && $(x).attr("loaded") != "true") {
- isReady = false;
- return false;
- } else {
- return true;
- }
- }
- });
- if (isReady && $(this).length > 0 && $.data(this, "cmsXDataTable")) {
- var opts = $.data(this, "cmsXDataTable").options;
- opts.pageNumber = 1;
- _load(this, formData, false);
- }
- });
- },
- clearOrderByAsc: function (jq) {
- jq.each(function () {
- _clearOrderByAsc(this);
- });
- },
- loadNextPage: function (jq) {
- jq.each(function () {
- var opts = $.data(this, "cmsXDataTable").options;
- if (opts.data) {
- if (opts.pagerType == 0) {
- if ((opts.pageNumber - 1) * opts.pageSize + opts.data.rows.length < opts.data.total) {
- opts.pageNumber += 1;
- _load(this, opts.queryParams, false);
- }
- } else if (opts.pagerType == 1) {
- if (opts.data.rows.length < opts.data.total) {
- opts.pageNumber += 1;
- _load(this, opts.queryParams, false);
- }
- }
- }
- });
- },
- loadAll: function (jq, formData) {
- jq.each(function () {
- var opts = $.data(this, "cmsXDataTable").options;
- opts.pageNumber = 1;
- _load(this, formData, true);
- });
- },
- reload: function (jq) {
- jq.each(function () {
- var opts = $.data(this, "cmsXDataTable").options;
- opts.pageNumber = 1;
- _load(this, null, true);
- });
- },
- orderLoad: function (jq, orderby) {
- jq.each(function () {
- var opts = $.data(this, "cmsXDataTable").options;
- opts.pageNumber = 1;
- _load(this, null, true, orderby.field, orderby.isAsc);
- });
- },
- loadData: function (jq, data) {
- jq.each(function () {
- var opts = $.data(this, "cmsXDataTable").options;
- opts.pageNumber = 1;
- _loadData(this, data, true);
- });
- },
- loadCurPageData: function (jq, data) {
- jq.each(function () {
- _loadData(this, data, true);
- });
- },
- getRowDataByObj: function (jq, obj) {
- return _getRowDataByObj(jq[0], obj);
- },
- getRows: function (jq) {
- return _getRows(jq[0]);
- },
- getTotal: function (jq) {
- return _getTotal(jq[0]);
- },
- getSelections: function (jq) {
- return _getSelections(jq[0]);
- },
- clearSelections: function (jq) {
- jq.each(function () {
- _clearSelections(this);
- });
- },
- deleteSubRowItem: function (jq, delData) {
- jq.each(function () {
- _deleteSubRowItem(this, delData);
- }
- );
- },
- setDataValueByIndex: function (jq, parameters) {
- var rowIndex = parameters.rowIndex;
- var columnName = parameters.columnName;
- var newValue = parameters.newValue;
- jq.each(function () {
- var opts = $.data(this, "cmsXDataTable").options;
- var table = $.data(this, "cmsXDataTable").table;
- var columnList = $.data(this, "cmsXDataTable").columnList;
- var columnOptsList = $.grep(columnList, function (x) { return x.field == columnName; });
- var columnOpts = null;
- if (columnOptsList.length > 0) {
- columnOpts = $.grep(columnList, function (x) { return x.field == columnName; })[0];
- }
- _changeDataJson(table, rowIndex, columnName, newValue, columnOpts);
- });
- },
- calMaxSize: function (jq) {
- jq.each(function() {
- _calMaxSize(this);
- });
- }
- };
- $.fn.cmsXDataTable.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsXDataTable.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsXDataTable.column = {
- defaults: {
- defaultValue: ' ',
- field: '',
- formatter: function (value, row, index) {
- return value;
- }
- }
- };
- $.fn.cmsXDataTable.defaults = {
- pageNumber: 1,
- pageSize: 10,
- loadMsg: "努力加载中...",
- emptyMsg: "",
- pagination: true,
- autoLoad: true,
- rowHighlightColor: null,
- isMouseOverHighlight: false,
- RowHighlightFun: "true",
- isAutoHeight: true,
- onSubRowItemDelete: null,
- checkOnSelect: true,
- rowStyle: function (index, row) {
- },
- onLoadSuccess: function (data) {
- },
- onLoadError: function () {
- },
- onBeforeLoad: function (param) {
- },
- //暂未实现
- onClickRow: function (rowIndex, rowData) {
- },
- //暂未实现
- onDblClickRow: function (rowIndex, rowData) {
- },
- //暂未实现
- onClickCell: function (rowIndex, field, value) {
- },
- //暂未实现
- onDblClickCell: function (rowIndex, field, value) {
- }
- };
- $(window).resize(function () {
- $(".cmsXDataTable").cmsXDataTable("calMaxSize");
- });
- })(jQuery);
- //2014-02-28 end added by pengbb 新增cmsXDataTable
- //2014-03-25 begin added by pengbb 新增cmsPanel控件
- (function ($) {
- $.parser.plugins.push("cmsPanel");
- function _init(jq) {
- var opts = $.data(jq, "cmsPanel").options;
- var _jqThis = $(jq);
- var isIE6 = false;
- if ($.browser.msie) {
- if ($.browser.version < 7) {
- isIE6 = true;
- }
- }
- var btnCollapsable = _jqThis.find(">div.panel-header>div.panel-tool>a.cmspanel-tool-collapse");
- btnCollapsable.unbind(".cmsPanel");
- btnCollapsable.bind("click.cmsPanel", function () {
- var _this = $(this);
- if (_this.hasClass("panel-tool-expand")) {
- _this.removeClass("panel-tool-expand");
- if (isIE6) {
- _jqThis.find("div.panel-body").show();
- } else {
- _jqThis.find("div.panel-body").slideDown();
- }
- if (typeof (opts.onExpanded) == "function") {
- opts.onExpanded.call(jq);
- }
- } else {
- _this.addClass("panel-tool-expand");
- if (isIE6) {
- _jqThis.find("div.panel-body").hide();
- } else {
- _jqThis.find("div.panel-body").slideUp();
- }
- if (typeof (opts.onExpanded) == "function") {
- opts.onCollapsed.call(jq);
- }
- }
- });
- return { cmsPanel: jq };
- }
- $.fn.cmsPanel = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsPanel.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsPanel(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsPanel");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsPanel", { options: $.extend({}, $.fn.cmsPanel.defaults, $.fn.cmsPanel.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsPanel", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.cmsPanel.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsPanel").options;
- return opts;
- }
- };
- $.fn.cmsPanel.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsPanel.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsPanel.defaults = {
- onExpanded: function () {
- },
- onCollapsed: function () {
- }
- };
- })(jQuery);
- //2014-03-25 end added by pengbb 新增cmspanel控件
- //2014-03-25 begin added by pengbb 新增cmsMenu控件
- (function ($) {
- $.parser.plugins.push("cmsMenu");
- var isIE6 = false;
- if ($.browser.msie) {
- if ($.browser.version < 7) {
- isIE6 = true;
- }
- }
- function _onMenuClick(jq, clickMenu) {
- var opts = $.data(jq, "cmsMenu").options;
- var _this = $(clickMenu);
- var node = { text: _this.attr("menuTitle"), url: _this.attr("menuUrl"), mnuNo: _this.attr("menuNo") };
- if (typeof (opts.onMenuClick) == "function") {
- opts.onMenuClick.call(jq, node);
- }
- }
- function _toggleChildMenu(currMenu) {
- var menuItemPanel = $(currMenu);
- if (!menuItemPanel.hasClass('nav_left_menuitem_expand')) {
- menuItemPanel.closest("li").siblings("li").removeClass('gradient');
- menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_expand').find(".nav_left_menuitem_right>div").removeClass('down_arrow');
- menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_expand').removeClass('nav_left_menuitem_expand');
- menuItemPanel.closest("li").siblings("li").find('>div.nav_left_menuitem_childpanel').slideUp("normal");
- menuItemPanel.next().next('div.nav_left_menuitem_childpanel').slideDown("normal");
- menuItemPanel.closest("li").addClass('gradient');
- menuItemPanel.addClass('nav_left_menuitem_expand');
- menuItemPanel.find(".nav_left_menuitem_right>div").addClass('down_arrow');
- } else {
- menuItemPanel.closest("li").removeClass('gradient');
- menuItemPanel.next().next('div.nav_left_menuitem_childpanel').slideUp("normal");
- menuItemPanel.removeClass('nav_left_menuitem_expand');
- menuItemPanel.find(".nav_left_menuitem_right>div").removeClass('down_arrow');
- }
- }
- function _toggleSecondChildMenu(currMenu) {
- var menuItemPanel = $(currMenu);
- if (!menuItemPanel.hasClass('nav_left_menuitem_second_expand')) {
- menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_second_expand').find(".node_plus").removeClass('node_minus');
- menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_second_expand').next().next('div.nav_left_menuitem_childpanel').slideUp("normal");
- menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_second_expand').removeClass('nav_left_menuitem_second_expand');
- menuItemPanel.next().next('div.nav_left_menuitem_childpanel').slideDown("normal");
- menuItemPanel.addClass('nav_left_menuitem_second_expand');
- menuItemPanel.find(".node_plus").addClass('node_minus');
- } else {
- menuItemPanel.removeClass('nav_left_menuitem_second_expand');
- menuItemPanel.find(".node_plus").removeClass('node_minus');
- menuItemPanel.next().next('div.nav_left_menuitem_childpanel').slideUp("normal");
- }
- }
- function _toggleThirdChildMenu(currMenu) {
- // var menuItemPanel = $(currMenu);
- // if (!menuItemPanel.hasClass('nav_left_menuitem_third_expand')) {
- //
- // //menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_third_expand').find(".node_plus").removeClass('node_minus');
- // menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_third_expand').removeClass('nav_left_menuitem_second_expand');
- // menuItemPanel.closest("li").siblings("li").find('div.nav_left_menuitem_third_expand').slideUp("normal");
- // menuItemPanel.next().next('div.nav_left_menuitem_childpanel').slideDown("normal");
- // menuItemPanel.addClass('nav_left_menuitem_third_expand');
- // //menuItemPanel.find(".node_plus").addClass('node_minus');
- // } else {
- //
- // menuItemPanel.removeClass('nav_left_menuitem_third_expand');
- // //menuItemPanel.find(".node_plus").removeClass('node_minus');
- // menuItemPanel.next().next('div.nav_left_menuitem_childpanel').slideUp("normal");
- // }
- }
- function _init(jq) {
- var opts = $.data(jq, "cmsMenu").options;
- var _jqThis = $(jq);
- //一级菜单
- _jqThis.find(".nav_left_menuitem").unbind(".cmsMenu");
- _jqThis.find(".nav_left_menuitem").bind("click.cmsMenu",
- function (event) {
- _toggleChildMenu(this);
- _onMenuClick(jq, $(this).find(".nav_left_menuitem_link"));
- return false;
- }
- );
- //二级菜单
- _jqThis.find(".nav_left_menuitem_second").unbind(".cmsMenu");
- _jqThis.find(".nav_left_menuitem_second").bind("click.cmsMenu",
- function (event) {
- _toggleSecondChildMenu(this);
- _onMenuClick(jq, $(this).find(".nav_left_menuitem_link"));
- return false;
- }
- );
- //二级菜单hover效果
- _jqThis.find(".nav_left_menuitem_second").bind("mouseenter.cmsMenu", function () {
- if (!$(this).hasClass("nav_left_menuitem_second_hover")) {
- $(this).addClass("nav_left_menuitem_second_hover");
- }
- });
- _jqThis.find(".nav_left_menuitem_second").bind("mouseleave.cmsMenu", function () {
- if ($(this).hasClass("nav_left_menuitem_second_hover")) {
- $(this).removeClass("nav_left_menuitem_second_hover");
- }
- });
- //三级菜单
- _jqThis.find(".nav_left_menuitem_third").unbind(".cmsMenu");
- _jqThis.find(".nav_left_menuitem_third").bind("click.cmsMenu",
- function (event) {
- _toggleThirdChildMenu(this);
- _onMenuClick(jq, $(this).find(".nav_left_menuitem_link"));
- return false;
- }
- );
- //三级菜单hover效果
- _jqThis.find(".nav_left_menuitem_third").bind("mouseenter.cmsMenu", function () {
- if (!$(this).hasClass("nav_left_menuitem_third_hover")) {
- $(this).addClass("nav_left_menuitem_third_hover");
- }
- });
- _jqThis.find(".nav_left_menuitem_third").bind("mouseleave.cmsMenu", function () {
- if ($(this).hasClass("nav_left_menuitem_third_hover")) {
- $(this).removeClass("nav_left_menuitem_third_hover");
- }
- });
- return { cmsMenu: jq };
- }
- $.fn.cmsMenu = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.cmsMenu.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.cmsMenu(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "cmsMenu");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "cmsMenu", { options: $.extend({}, $.fn.cmsMenu.defaults, $.fn.cmsMenu.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "cmsMenu", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.cmsMenu.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "cmsMenu").options;
- return opts;
- }
- };
- $.fn.cmsMenu.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.cmsPanel.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.cmsMenu.defaults = {
- onMenuClick: function (node) { }
- };
- })(jQuery);
- //2014-04-21 end added by pengbb 新增cmsMenu控件
- //2014-06-26 begin added by heyw 新增autoComplete控件
- (function ($) {
- $.parser.plugins.push("autoComplete");
- function _init(jq) {
- var opts = $.data(jq, "autoComplete").options;
- var top = 10;
- var _jqThis = $(jq);
- var isIE6 = false;
- if ($.browser.msie) {
- if ($.browser.version < 7) {
- isIE6 = true;
- }
- }
- var mainBox = _jqThis;
- var valueBox = $("#" + _jqThis.attr("id") + "_value");
- $(mainBox).autocomplete(opts.url, {
- max: top,
- minChars: 1,
- width: opts.width,
- scrollHeight: opts.scrollHeight,
- matchContains: opts.matchContains,
- mustMatch: opts.mustMatch,
- cacheLength: 50, //1- 无缓存
- autoFill: opts.autoFill,
- dataType: 'json',
- parse: function (data) {
- var parsed = [];
- for (var i = 0; i < data.length; i++) {
- parsed[parsed.length] = {
- data: data[i],
- value: data[i][opts.valueField].toString(),
- result: data[i][opts.textField]
- };
- }
- return parsed;
- },
- formatItem: opts.formatter,
- formatMatch: function (row, i, max) {
- return row[opts.textField];
- },
- formatResult: function (row) {
- $(valueBox).val(row[opts.valueField]);
- return row[opts.textField];
- }
- });
- if ($(valueBox).val())
- mainBox[0].setDefaultValue($(valueBox).val(), opts.textField, opts.valueField);
- return { autoComplete: jq };
- }
- $.fn.autoComplete = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.autoComplete.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.autoComplete(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "autoComplete");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "autoComplete", { options: $.extend({}, $.fn.autoComplete.defaults, $.fn.autoComplete.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "autoComplete", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.autoComplete.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "autoComplete").options;
- return opts;
- },
- setDefaultValue: function (jq, value) {
- }
- };
- $.fn.autoComplete.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.autoComplete.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.autoComplete.defaults = {
- width: 600,
- scrollHeight: 380,
- matchContains: true,
- mustMatch: true,
- autoFill: false,
- url: "",
- textField: "",
- valueField: "",
- defaltValue: "",
- formatter: function (row, i, max) {
- return i;
- }
- };
- })(jQuery);
- //2014-06-26 begin added by heyw 新增autoComplete控件
- //2014-08-13 begin added by heyw 新增draggableList控件
- (function ($) {
- $.parser.plugins.push("draggableList");
- function _init(jq) {
- var opts = $.data(jq, "draggableList").options;
- var listID = jq.id;
- var div = $("<div></div>").appendTo(jq);
- $.ajax({
- type: "post", url: opts.url, success: function (data) {
- var length = 0;
- $.each(data, function () {
- var htmlList = new Array();
- var className = listID + "_" + this[opts.valueField];
- htmlList.push("<div class=\"easyui-draggable " + className + "\" style=\"cursor: pointer; height: " + opts.itemHeight + "px; line-height: " + opts.itemHeight + "px; float: left;\">");
- if (opts.iconField && opts.iconField != "") {
- htmlList.push("<img style=\"margin-left: 2px; margin-top: 2px; margin-bottom: 2px; float: left;\" src=\"" + this[opts.iconField] + "\" border=\"0\" />");
- }
- htmlList.push("<div class=\"draggableTitle\" style=\"margin-left: 2px; margin-top: 2px; margin-bottom: 2px; color: " + opts.foreColor + "; position: relative; float: left;\" value=\"" + this[opts.valueField] + "\">" + this[opts.titleField] + "</div>");
- htmlList.push("</div>");
- var itemElement = $(htmlList.join(""));
- itemElement.appendTo(div);
- length += itemElement.width();
- $("." + className).draggable({
- handle: ".draggableTitle",
- proxy: "clone",
- revert: true,
- onDrag: function (e) {
- CMSFunction.DragDrop.dragX = e.clientX;
- CMSFunction.DragDrop.dragY = e.clientY;
- },
- onBeforeDrag: function (e) {
- CMSFunction.DragDrop.isInnerDrag = false;
- CMSFunction.DragDrop.offsetX = e.offsetX + e.srcElement.offsetLeft - e.srcElement.parentElement.offsetLeft;
- CMSFunction.DragDrop.offsetY = e.offsetY + e.srcElement.offsetTop - e.srcElement.parentElement.offsetTop;
- }
- });
- });
- div.width(length);
- //$(jq).height(opts.itemHeight + 16);
- }
- });
- return { draggableList: jq };
- }
- $.fn.draggableList = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.draggableList.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.draggableList(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "draggableList");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "draggableList", { options: $.extend({}, $.fn.draggableList.defaults, $.fn.draggableList.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "draggableList", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.draggableList.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "draggableList").options;
- return opts;
- },
- setDefaultValue: function (jq, value) {
- }
- };
- $.fn.draggableList.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.draggableList.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.draggableList.defaults = {
- url: "",
- titleField: "",
- valueField: "",
- iconField: "",
- itemHeight: 0,
- foreColor: "#000000"
- };
- })(jQuery);
- //2014-08-13 begin added by heyw 新增draggableList控件
- //2014-08-18 begin added by heyw 新增droppableContainer控件
- (function ($) {
- $.parser.plugins.push("droppableContainer");
- function _init(jq) {
- var opts = $.data(jq, "droppableContainer").options;
- var listID = jq.id;
- var myLeft = jq.clientLeft;
- var myTop = jq.clientTop;
- var myWidth = jq.clientWidth;
- var myHeight = jq.clientHeight;
- document.body.oncontextmenu = function (e) {
- e = e || window.event;
- var target = e.target || e.srcElement;
- if (($(target).hasClass("easyui-draggable") && $(target).parent().hasClass("easyui-droppableContainer"))
- || ($(target).parent().hasClass("easyui-draggable") && $(target).parent().parent().hasClass("easyui-droppableContainer"))) {
- CMSFunction.DragDrop.DropContainerItemClick(e);
- return false;
- }
- }
- if (opts.url && opts.url != "") {
- $.ajax({
- type: "post", url: opts.url, success: function (data) {
- $.each(data, function () {
- var htmlList = new Array();
- var className = listID + "_" + this[opts.valueField];
- htmlList.push("<div class=\"easyui-draggable " + className + "\" style=\"cursor: pointer; position: absolute; height: " + opts.itemHeight + "px; line-height: " + opts.itemHeight + "px; float: left; left: " + this[opts.leftField] + "px; top: " + this[opts.topField] + "px; \">");
- if (opts.iconField && opts.iconField != "") {
- htmlList.push("<img style=\"margin-top: 2px; margin-bottom: 2px; margin-left: 2px; float: left;\" border=\"0\" src=\"" + this[opts.iconField] + "\">");
- }
- htmlList.push("<div class=\"draggableTitle\" style=\"color: " + opts.foreColor + "; margin-left: 2px; margin-top: 2px; margin-bottom: 2px; float: left;\" value=\"" + this[opts.valueField] + "\">" + this[opts.titleField] + "</div>");
- htmlList.push("</div>");
- $(htmlList.join("")).appendTo(jq);
- $("." + className).draggable({
- handle: ".draggableTitle",
- onDrag: function (e) {
- CMSFunction.DragDrop.dragX = e.clientX;
- CMSFunction.DragDrop.dragY = e.clientY;
- },
- onBeforeDrag: function (e) {
- CMSFunction.DragDrop.isInnerDrag = true;
- CMSFunction.DragDrop.offsetX = e.offsetX;
- CMSFunction.DragDrop.offsetY = e.offsetY;
- },
- onStopDrag: function (e) {
- if (e.clientX < myLeft || e.clientX > myLeft + myWidth || e.clientY < myTop || e.clientY > myTop + myHeight) {
- $(e.srcElement).offsetParent().remove();
- }
- }
- });
- });
- }
- });
- }
- else if (opts.items && opts.items.length > 0) {
- $.each(opts.items, function () {
- var htmlList = new Array();
- var className = listID + "_" + this.value;
- htmlList.push("<div class=\"easyui-draggable " + className + "\" style=\"cursor: pointer; position: absolute; height: " + opts.itemHeight + "px; line-height: " + opts.itemHeight + "px; float: left; left: " + this.left + "px; top: " + this.top + "px; \">");
- if (this.icon && this.icon != "") {
- htmlList.push("<img style=\"margin-top: 2px; margin-bottom: 2px; margin-left: 2px; float: left;\" border=\"0\" src=\"" + this.icon + "\">");
- }
- htmlList.push("<div class=\"draggableTitle\" style=\"color: " + opts.foreColor + "; margin-left: 2px; margin-top: 2px; margin-bottom: 2px; float: left;\" value=\"" + this.value + "\">" + this.title + "</div>");
- htmlList.push("</div>");
- $(htmlList.join("")).appendTo(jq);
- $("." + className).draggable({
- handle: ".draggableTitle",
- onDrag: function (e) {
- CMSFunction.DragDrop.dragX = e.clientX;
- CMSFunction.DragDrop.dragY = e.clientY;
- },
- onBeforeDrag: function (e) {
- CMSFunction.DragDrop.isInnerDrag = true;
- CMSFunction.DragDrop.offsetX = e.offsetX;
- CMSFunction.DragDrop.offsetY = e.offsetY;
- },
- onStopDrag: function (e) {
- if (e.clientX < myLeft || e.clientX > myLeft + myWidth || e.clientY < myTop || e.clientY > myTop + myHeight) {
- $(e.srcElement).offsetParent().remove();
- }
- }
- });
- });
- }
- $(jq).droppable({});
- var hidden = $(jq).next();
- hidden.val('');
- $.each($(jq).find('.easyui-draggable'), function () {
- var valStr = '';
- if (hidden.val() != '') valStr = ',';
- var titleDiv = $(this).find('.draggableTitle');
- valStr += titleDiv.attr('value') + '|' + titleDiv.html() + '|' + $(this).css('left').replace("px", "") + '|' + $(this).css('top').replace("px", "");
- hidden.val(hidden.val() + valStr);
- });
- return { droppableContainer: jq };
- }
- $.fn.droppableContainer = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.droppableContainer.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.droppableContainer(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "droppableContainer");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "droppableContainer", { options: $.extend({}, $.fn.droppableContainer.defaults, $.fn.droppableContainer.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "droppableContainer", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.droppableContainer.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "droppableContainer").options;
- return opts;
- },
- getContainerItems: function (jq) {
- var hidden = jq.next();
- var valStr = hidden.val();
- var items = valStr.split(',');
- var result = new Array();
- $.each(items, function () {
- var colVals = this.split('|');
- result.push({
- Icon: null,
- Value: colVals[0],
- Title: colVals[1],
- Left: parseInt(colVals[2]),
- Top: parseInt(colVals[3])
- });
- });
- return result;
- }
- };
- $.fn.droppableContainer.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.droppableContainer.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.droppableContainer.defaults = {
- title: "",
- value: "",
- icon: "",
- height: 0,
- foreColor: "#000000"
- };
- })(jQuery);
- //2014-08-18 begin added by heyw 新增droppableContainer控件
- //2015-12-08 begin added by heyw 新增combogridX控件
- (function ($) {
- $.parser.plugins.push("combogridX");
- function _init(jq) {
- var opts = $.data(jq, "combogridX").options;
- var bubbleKeyup = true;
- var oldValue;
- var lastScoreHeight = 0;
- var expander = $(jq).find(".combogridX-expander");
- if (opts.panelWidth) {
- $(expander).width(opts.panelWidth);
- }
- $(document).click(function () {
- if ($(event.srcElement).parents(".easyui-combogridX").length == 0) {
- $('.combogridX-expander').css("display", "none");
- }
- });
- var gridTable = $(jq).find('.easyui-cmsXDataTable');
- var beforeScrollTop = $(gridTable).scrollTop();
- $(expander).scroll(function (event) {
- event = event || window.event;
- var afterScrollTop = $(gridTable).scrollTop;
- delta = afterScrollTop - beforeScrollTop;
- beforeScrollTop = afterScrollTop;
- var scrollTop = $(this).scrollTop();
- var scrollHeight = $(gridTable).height();
- var windowHeight = $(this).height();
- if (scrollTop + windowHeight >= (scrollHeight - 10) && lastScoreHeight != scrollHeight) { //滚动到底部执行事件
- lastScoreHeight = scrollHeight;
- gridTable.cmsXDataTable("loadNextPage");
- return;
- }
- });
- $(jq).find(".combo-arrow").mouseover(function () {
- $(this).addClass("combogridX-arrow-hover");
- });
- $(jq).find(".combo-arrow").mouseout(function () {
- $(this).removeClass("combogridX-arrow-hover");
- });
- $(jq).find(".combo-clear").mouseover(function () {
- $(this).addClass("combo-clear-hover");
- });
- $(jq).find(".combo-clear").mouseout(function () {
- $(this).removeClass("combo-clear-hover");
- });
- var comboText = $(jq).find(".combo-text");
- var controlWidth = comboText.width() + 4;
- if ($(jq).attr("width")) {
- controlWidth = parseInt($(jq).attr("width"));
- }
- comboText.width(controlWidth - 36 - 3);
- $(jq).width(controlWidth);
- $(jq).find(".combo-arrow").offset({
- top: $(jq).find(".combo-arrow").offset().top,
- left: $(jq).find(".combo-arrow").offset().left + 18
- });
- if (comboText.attr("placeholder") && $(jq).attr("placeholder") != "") {
- comboText.placeholder();
- }
- //设置相应事件
- if (opts.enabled == true) {
- $(jq).find(".combo-arrow").click(function () {
- var dropdown = $(this).parents('.easyui-combogridX:first');
- var expander = dropdown.find(".combogridX-expander");
- var display = expander.css("display");
- $('.combogridX-expander').css("display", "none");
- if (display == "none") {
- _showExpander(expander, dropdown, $(this));
- }
- else expander.css("display", "none");
- });
- $(jq).find(".combo-clear").click(function () {
- var dropdown = $(this).parents('.easyui-combogridX:first');
- var comboText = dropdown.find(".combo-text");
- CMSFunction.ComboGrid.SetValue(dropdown, "", "-1");
- if (opts.isAutoComplete) {
- _autoComplete(comboText, true, oldValue, { keyCode: 8 });
- }
- $('.combogridX-expander').css("display", "none");
- if (opts.onSelect) opts.onSelect.call(this, null);
- });
- }
- if (opts.value != '' && opts.value != -1 && opts.text != '') {
- CMSFunction.ComboGrid.SetValue($(jq), opts.text, opts.value);
- }
- if (opts.isAutoComplete) {
- $(jq).find(".combo-text")
- // .keyup(function (ev) {
- // _autoComplete($(this), bubbleKeyup, oldValue, ev);
- // })
- .keydown(function (ev) {
- // oldValue = $(this).val();
- // if (ev.keyCode == 229) {
- // bubbleKeyup = false;
- // } else {
- // bubbleKeyup = true;
- // }
- var selfControl = $(this);
- clearTimeout(selfControl.timeoutFunc);
- $(this).timeoutFunc = setTimeout(function() {
- _autoComplete(selfControl, bubbleKeyup, null, ev);
- }, 300);
- });
- }
- return { combogridX: jq };
- }
- function _autoComplete(comboText, bubbleKeyup, oldValue, ev) {
- // if (!bubbleKeyup && ev.keyCode != 32 && ev.keyCode != 13
- // && (oldValue.indexOf(comboText.val()) >= 0
- // || (ev.keyCode == 229 && comboText.val().indexOf(oldValue) >= 0)
- // )) {
- // bubbleKeyup = false;
- // return;
- // }
- var dropdown = comboText.parents('.easyui-combogridX:first');
- var grid = dropdown.find('.easyui-cmsXDataTable');
- var opts = $.data(dropdown[0], "combogridX").options;
- var formData = opts.formData;
- if (comboText.val().length >= opts.minReloadCharactor) {
- var expander = dropdown.find(".combogridX-expander");
- var arrow = dropdown.find(".combo-arrow");
- var display = expander.css("display");
- if (display == "none") {
- _showExpander(expander, dropdown, arrow);
- }
- var queryParamString = "";
- if (formData) {
- queryParamString = formData.QueryParamsDatas;
- }
- var queryText = comboText.val();
- if (queryText == opts.emptyText) {
- queryText = "";
- }
- var jsonString = "({'QueryParamsDatas':'Attribute|*|{\"ID\":\"00000000-0000-0000-0000-000000000000\",\"Value\":\"" + opts.textField
- + "\",\"ControlType\":\"TextBox\"}|@|Condition|*|中|@|ConditionValue|*|" + comboText.val()
- + "|@|" + opts.textField + "_QueryTextBox|*|" + queryText + "|@|" + queryParamString + "'})";
- try {
- grid.cmsXDataTable("loadAll", eval(jsonString));
- }
- catch (err) { }
- }
- }
- function _showExpander(expander, dropdown, arrow) {
- expander.css("display", "block");
- _setExpanderPosition(expander, dropdown, arrow);
- }
- function _setExpanderPosition(expander, dropdown, arrow) {
- var panelLeft = expander.position().left;
- var panelWidth = expander.width();
- var panelHeight = expander.height();
- var dropdownLeft = dropdown.position().left;
- var dropdownTop = dropdown.offset().top;
- var dropdownHeight = dropdown.height();
- var panelTop = (dropdownTop + dropdownHeight);
- var arrowLeft = arrow.position().left;
- var documentWidth = $(window).width();
- var documentHeight = $(window).height() - 5;
- var newTop = 0;
- var newLeft = 0;
- if (panelTop + panelHeight >= documentHeight) {
- if (panelHeight < dropdownTop) {
- newTop = dropdownTop - panelHeight;
- } else if (dropdownTop >= (documentHeight - panelTop)) { //当下拉控件位置偏下……
- newTop = 0;
- expander.height(documentHeight - panelTop);
- } else { //当下拉控件位置偏上……
- newTop = panelTop;
- expander.height(documentHeight - panelTop);
- }
- } else {
- newTop = panelTop;
- }
- if (dropdownLeft + panelWidth > documentWidth - 16) {
- newLeft = arrowLeft + arrow.width() - panelWidth;
- if (newLeft < 2) newLeft = 2;
- }
- else {
- newLeft = dropdownLeft;
- }
- //设置高度如果用offset的话,第一次点击时,如果窗口被滚动过,会忽略滚动条来设置高度,第二次又不会了,不知道为什么……
- expander.position({
- top: newTop
- });
- expander.offset({
- left: newLeft
- });
- }
- function _setValue(jq, val, callback) {
- if (!val) {
- CMSFunction.ComboGrid.SetValue($(jq), "", "");
- return;
- } else if (val == "" || val == "-1") {
- CMSFunction.ComboGrid.SetValue($(jq), "", val);
- return;
- }
- var opts = $.data(jq, "combogridX").options;
- var grid = $(jq).find('.easyui-cmsXDataTable:first');
- var jsonString = "({'QueryParamsDatas':'Attribute|*|{\"ID\":\"00000000-0000-0000-0000-000000000000\",\"Value\":\"" + opts.valueField
- + "\",\"ControlType\":\"TextBox\"}|@|Condition|*|=|@|ConditionValue|*|" + opts.value
- + "|@|" + opts.valueField + "_QueryTextBox|*|" + val + "|@|',page: 0,rows: 10 })";
- try {
- var gridOptions = grid.cmsXDataTable("options");
- var url = gridOptions.url;
- $.post(url, eval(jsonString), function (data) {
- if (data.rows.length > 0) {
- CMSFunction.ComboGrid.SetValue($(jq), data.rows[0][opts.textField], val);
- if (callback) {
- callback.call($(jq));
- }
- }
- });
- }
- catch (err) { }
- // var gridOpts = $.data(grid[0], "cmsXDataTable").options;
- // var gridData = gridOpts.data;
- // CMSFunction.ComboGrid.SetValue($(jq), "", "-1");
- // if (gridData) {
- // $.each(gridData.rows, function (i, v) {
- // if (v[opts.valueField] == val) {
- // CMSFunction.ComboGrid.SetValue($(jq), v[opts.textField], v[opts.valueField]);
- // return false;
- // }
- // });
- // }
- }
- function _getValue(jq) {
- return $(jq).find('.combogridX-value').val();
- }
- function _getSelectedRow(jq) {
- var value = _getValue(jq);
- var opts = $.data(jq, "combogridX").options;
- var grid = $(jq).find('.easyui-cmsXDataTable:first');
- var gridOpts = $.data(grid[0], "cmsXDataTable").options;
- var gridData = gridOpts.data;
- var selectedRow = null;
- if (gridData) {
- $.each(gridData.rows, function (i, v) {
- if (v[opts.valueField] == value) {
- selectedRow = v;
- return false;
- }
- });
- }
- return selectedRow;
- }
- function _getText(jq) {
- return $(jq).find('.combo-text').val();
- }
- function _loadData(jq, data) {
- jq.each(function () {
- var grid = $(jq).parent().find('.easyui-cmsXDataTable:first');
- if (!$.data(grid[0], "cmsXDataTable")) return;
- grid.cmsXDataTable("loadData", data);
- });
- }
- function _reload(jq, formData) {
- jq.each(function () {
- var grid = $(jq).parent().find('.easyui-cmsXDataTable:first');
- if (!$.data(grid[0], "cmsXDataTable")) return;
- var opts = $.data(grid[0], "cmsXDataTable").options;
- opts.pageNumber = 1;
- if (typeof formData == "string") {
- opts.url = formData;
- grid.cmsXDataTable("loadAll", '');
- }
- else {
- $.data(this, "combogridX").options.formData = formData;
- grid.cmsXDataTable("loadAll", formData);
- }
- });
- }
- function _select(jq, index) {
- var grid = $(jq).parent().find('.easyui-cmsXDataTable:first');
- var opts = $.data(jq, "combogridX").options;
- if (!$.data(grid[0], "cmsXDataTable")) return;
- var data = grid.cmsXDataTable("getRows");
- if (data[index]) {
- var selectedText = eval("data[index]." + opts.textField);
- var selectedValue = eval("data[index]." + opts.valueField);
- CMSFunction.ComboGrid.SetValue($(jq), selectedText, selectedValue);
- }
- }
- $.fn.combogridX = function (_7be, _7bf, _7bg) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.combogridX.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf, _7bg);
- } else {
- return this.combogridX(_7be, _7bf, _7bg);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "combogridX");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "combogridX", { options: $.extend({}, $.fn.combogridX.defaults, $.fn.combogridX.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "combogridX", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.combogridX.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "combogridX").options;
- return opts;
- },
- getValue: function (jq) {
- return _getValue(jq[0]);
- },
- getSelectedRow: function (jq) {
- return _getSelectedRow(jq[0]);
- },
- setValue: function (jq, val, callback) {
- _setValue(jq[0], val, callback);
- },
- select: function (jq, index) {
- _select(jq[0], index);
- },
- getText: function (jq) {
- return _getText(jq[0]);
- },
- reload: function (jq, formData) {
- _reload(jq, formData);
- },
- loadData: function (jq, data) {
- _loadData(jq, data);
- },
- setExpanderPosition: function (jq, opts) {
- _setExpanderPosition(opts.expander, opts.dropdown, opts.arrow);
- }
- };
- $.fn.combogridX.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.combogridX.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.combogridX.defaults = {
- textField: "",
- valueField: "",
- isAutoComplete: true,
- minReloadCharactor: 0,
- onSelect: function (value) { },
- onChange: function () { },
- panelHeight: 300,
- formData: null,
- value: "",
- enabled: true,
- };
- })(jQuery);
- //2014-08-18 begin added by heyw 新增droppableContainer控件
- $(function () {
- $.parser.parseEasyUI(["autoComplete"]);
- $.parser.parseEasyUI(["combogridX"]);
- $.parser.parseEasyUI(["draggableList"]);
- $.parser.parseEasyUI(["droppableContainer"]);
- $.parser.parseEasyUI(["checkList"]);
- $.parser.parseEasyUI(["richtext"]);
- //$(".popupWindowContent").width(window.);
- });
- $.extend({
- popupTopWindow: function (title, url, width, height, func, data) {
- var containerTop = top.$('#sysWindow').parent();
- var windowID = "sysWindow" + Math.floor(Math.random() * 100000 + 1);
- $("<div id=\"" + windowID + "\" />").appendTo(containerTop);
- var loU = url.split("?");
- var newUrl = url;
- if (loU.length > 1) {
- newUrl += "&WindowID=" + windowID;
- } else {
- newUrl += "?WindowID=" + windowID;
- }
- if (data) {
- top.$('#' + windowID).data("inputData", data);
- }
- var windowHeight = $(top.document).height();
- if (windowHeight < height) {
- height = windowHeight;
- }
- top.$('#' + windowID).dialog({
- title: title,
- width: width,
- height: height,
- content: '<iframe id="iframe1" frameborder="0" scrolling="no" ></iframe>',
- modal: true,
- onClose: function () {
- if (func)
- func.call(this, top.$('#' + windowID).data("resultData"));
- },
- onOpen: function () {
- $(this).find("iframe").attr("src", newUrl);
- }
- });
- return top.$('#' + windowID);
- },
- popupTopWindowOutsite: function (title, url, width, height, func, data) {
- var containerTop = top.$('#sysWindow').parent();
- var windowID = "sysWindow" + Math.floor(Math.random() * 100000 + 1);
- $("<div id=\"" + windowID + "\" />").appendTo(containerTop);
- if (data) {
- top.$('#' + windowID).data("inputData", data);
- }
- var windowHeight = $(top.document).height();
- if (windowHeight < height) {
- height = windowHeight;
- }
- top.$('#' + windowID).dialog({
- title: title,
- width: width,
- height: height,
- content: '<iframe id="iframe1" frameborder="0" scrolling="yes" ></iframe>',
- modal: true,
- onClose: function () {
- if (func)
- func.call(this, top.$('#' + windowID).data("resultData"));
- },
- onOpen: function () {
- $(this).find("iframe").attr("src", url);
- }
- });
- return top.$('#' + windowID);
- },
- closeCurPopupTopWindow: function () {
- var windowID = $.SystemGeneral.getUrlParam("WindowID");
-
- top.$("#" + windowID).dialog("close");
- },
- getPopupTopWindowInputData: function () {
- var windowID = $.SystemGeneral.getUrlParam("WindowID");
-
- return top.$('#' + windowID).data("inputData");
- }
- });
- //2016-02-25 begin added by heyw 新增checkList控件
- (function ($) {
- $.parser.plugins.push("checkList");
- function _init(jq) {
- var opts = $.data(jq, "checkList").options;
- if (opts.url && opts.url != "") {
- $.ajax({
- type: "post", url: opts.url, success: function (data) {
- opts.data = data;
- opts.values = $.map($.grep(data, function (x) { return x.IsSelected; }), function (x) { return x[opts.valueField]; });
- _getInitValuesAndLoad(jq, opts);
- }
- });
- }
- else {
- _getInitValuesAndLoad(jq, opts);
- }
- return { checkList: jq };
- }
- var _getInitValuesAndLoad = function (jq, opts) {
- if (opts.valueUrl && opts.valueUrl != "") {
- $.ajax({
- type: "post", url: opts.valueUrl, success: function (valueData) {
- opts.values = valueData;
- _bind(jq);
- }
- });
- }
- else {
- _bind(jq);
- }
- };
- var _bind = function (jq) {
- var opts = $.data(jq, "checkList").options;
- var listID = jq.id;
- var html = new Array();
- var textField = opts.textField;
- var valueField = opts.valueField;
- if (!(textField && textField != "")) {
- textField = "Text";
- }
- if (!(valueField && valueField != "")) {
- valueField = "Value";
- }
- var styleHtml = new Array();
- if (!opts.isShow) styleHtml.push('display: none;');
- var pages = Math.ceil(opts.data.length / opts.columnCount);
- html.push('<table border="0" width="100%"');
- if (styleHtml.length > 0) html.push(' style="' + styleHtml.join('') + '"');
- html.push('>');
- for (var i = 0; i < pages; i++) {
- html.push('<tr>');
- for (var j = 0; j < opts.columnCount; j++) {
- var curIndex = (i * opts.columnCount + j);
- if (opts.data.length > curIndex) {
- var checked = $.inArray(opts.data[curIndex][valueField], opts.values) >= 0;
- var checkedString = "";
- if (checked) checkedString = " checked";
- var enabledString = "";
- if (!opts.isEnabled) enabledString = " disabled";
- html.push('<td>');
- html.push(''.concat('<input name="', opts.checkName, '"', checkedString, ' type="checkbox" value="',
- opts.data[curIndex][valueField], '"', enabledString, '/>', opts.data[curIndex][textField]));
- html.push('</td>');
- }
- else {
- html.push('<td> </td>');
- }
- }
- html.push('</tr>');
- }
- html.push('</table>');
- var div = $(''.concat("<div>", html.join(''), "</div>")).appendTo(jq);
- if (opts.onclick) {
- $(jq).find('input[name="' + opts.checkName + '"]').click(opts.onclick);
- }
- if (opts.onLoadSuccess) {
- opts.onLoadSuccess.call(jq, opts.data);
- }
- };
- $.fn.checkList = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.checkList.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.checkList(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "checkList");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "checkList", { options: $.extend({}, $.fn.checkList.defaults, $.fn.checkList.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "checkList", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.checkList.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "checkList").options;
- return opts;
- }
- };
- $.fn.checkList.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.checkList.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.checkList.defaults = {
- url: "",
- valueUrl: "",
- textField: "",
- valueField: "",
- columnCount: 1,
- data: [],
- values: [],
- onLoadSuccess: function (data) { },
- isEnabled: true,
- isShow: true
- };
- })(jQuery);
- //2016-02-25 begin added by heyw 新增richtext控件
- //2021-05-10 modify by heyw 实际控件从ueditor改为kindeditor
- (function ($) {
- $.parser.plugins.push("richtext");
- var ueList = new Object();
- function _init(jq) {
- var id = $(jq).attr("id");
- var name = $(jq).attr("name");
- // var ue = new baidu.editor.ui.Editor();
- // ue.render(id);
- var ke;
- KindEditor.ready(function (K) {
- ke = K.create('#' + id, {
- uploadJson: K.options.basePath + 'asp.net/upload_json.ashx',
- fileManagerJson: K.options.basePath + 'asp.net/file_manager_json.ashx'
- });
- if (!ueList["richtext_" + id]) {
- //ueList["richtext_" + id] = { name: name, editor: ue };
- ueList["richtext_" + id] = { name: name, editor: ke };
- }
- });
- $(jq).closest('form').submit(function () {
- $(".easyui-richtext").richtext("sync");
- });
- return { richtext: jq };
- }
- function _getValue(jq) {
- var id = $(jq).attr("id");
- //var ue = ueList["richtext_" + id].editor;
- //return ue.getContent();
- var ke = ueList["richtext_" + id].editor;
- ke.sync();
- return editor.html();
- }
- function _setValue(jq, value) {
- var id = $(jq).attr("id");
- // var ue = ueList["richtext_" + id].editor;
- // return ue.setContent(value);
- var ke = ueList["richtext_" + id].editor;
- return editor.html(value);
- }
- function _sync(jq) {
- var id = $(jq).attr("id");
- var opts = ueList["richtext_" + id]
- // var ue = opts.editor;
- //
- // ue.sync();
- // var content = ue.getContent();
- // content = UE.utils.unhtml(content);
- // content = content.replace(/'/g,'');
- var ke = opts.editor;
- var content = ke.html();
- content = KindEditor.escape(content);
- $('[name="' + opts.name + '"]').val(content);
- }
- $.fn.richtext = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.richtext.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.richtext(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "richtext");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "richtext", { options: $.extend({}, $.fn.richtext.defaults, $.fn.richtext.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "richtext", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.richtext.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "richtext").options;
- return opts;
- },
- getValue: function (jq) {
- return _getValue(jq[0]);
- },
- setValue: function (jq, val) {
- $.each(jq, function (i, v) {
- _setValue(jq[i], val);
- });
- },
- sync: function (jq) {
- $.each(jq, function (i, v) {
- _sync(jq[i]);
- });
- }
- };
- $.fn.richtext.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.richtext.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.richtext.defaults = {
- isEnabled: true,
- isShow: true
- };
- })(jQuery);
- //2016-02-25 begin added by heyw 新增checkList控件
- (function ($) {
- $.parser.plugins.push("qqList");
- function _init(jq) {
- var opts = $.data(jq, "qqList").options;
- if (opts.url && opts.url != "") {
- $.ajax({
- type: "post", url: opts.url, success: function (data) {
- opts.data = data;
- _bind(jq);
- }
- });
- }
- else {
- _bind(jq);
- }
- return { qqList: jq };
- }
- var _bind = function (jq) {
- var opts = $.data(jq, "qqList").options;
- var listID = jq.id;
- var html = new Array();
- var textField = opts.textField;
- var valueField = opts.valueField;
- if (!(textField && textField != "")) {
- textField = "Text";
- }
- if (!(valueField && valueField != "")) {
- valueField = "Value";
- }
- var styleHtml = new Array();
- var pages = Math.ceil(opts.data.length / opts.columnCount);
- html.push('<table border="0" width="100%"');
- if (styleHtml.length > 0) html.push(' style="' + styleHtml.join('') + '"');
- html.push('>');
- for (var i = 0; i < pages; i++) {
- html.push('<tr>');
- for (var j = 0; j < opts.columnCount; j++) {
- var curIndex = (i * opts.columnCount + j);
- if (opts.data.length > curIndex) {
- var enabledString = "";
- var qqNo = opts.data[curIndex][valueField];
- if (!opts.isEnabled) enabledString = " disabled";
- html.push('<td>');
- html.push('<a name="', opts.itemName, '" href="tencent://Message/?Uin=' + qqNo + '&websiteName=q-zone.qq.com&Menu=yes"' + enabledString + '>')
- html.push('<div><span style="text-align: center;"><img src="http://q2.qlogo.cn/headimg_dl?dst_uin=' + qqNo + '&spec=100" ');
- html.push('style="border: 0px; width: ' + opts.itemWidth + '; height: ' + opts.itemHeight + '"/></span>');
- html.push(''.concat('<span style="text-align: center;">', opts.data[curIndex][textField], '</span>'));
- html.push('</div></a></td>');
- }
- else {
- html.push('<td> </td>');
- }
- }
- html.push('</tr>');
- }
- html.push('</table>');
- var div = $(''.concat("<div>", html.join(''), "</div>")).appendTo(jq);
- if (opts.onclick) {
- $(jq).find('a[name="' + opts.itemName + '"]').click(opts.onclick);
- }
- if (opts.onLoadSuccess) {
- opts.onLoadSuccess.call(jq, opts.data);
- }
- };
- $.fn.qqList = function (_7be, _7bf) {
- if (typeof _7be == "string") {
- var _7c0 = $.fn.qqList.methods[_7be];
- if (_7c0) {
- return _7c0(this, _7bf);
- } else {
- return this.qqList(_7be, _7bf);
- }
- }
- _7be = _7be || {};
- return this.each(function () {
- var _this = this;
- var cacheData = $.data(_this, "qqList");
- if (cacheData) {
- $.extend(cacheData.options, _7be);
- } else {
- cacheData = $.data(_this, "qqList", { options: $.extend({}, $.fn.qqList.defaults, $.fn.qqList.parseOptions(this), _7be) });
- var initCacheData = _init(_this);
- cacheData = $.data(_this, "qqList", $.extend({}, cacheData, initCacheData));
- }
- });
- };
- $.fn.qqList.methods = {
- options: function (jq) {
- var opts = $.data(jq[0], "qqList").options;
- return opts;
- }
- };
- $.fn.qqList.parseOptions = function (_7c7) {
- var t = $(_7c7);
- return $.extend({}, $.fn.qqList.defaults, $.parser.parseOptions(_7c7, []));
- };
- $.fn.qqList.defaults = {
- url: "",
- textField: "",
- columnCount: 1,
- data: [],
- onLoadSuccess: function (data) { },
- isEnabled: true,
- isShow: true
- };
- })(jQuery);
|