FarmtopServiceImpl.java 3.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
package com.farm.doc.server.impl;

import javax.annotation.Resource;

import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import com.farm.core.auth.domain.LoginUser;
import com.farm.core.sql.query.DataQuery;
import com.farm.core.time.TimeTool;
import com.farm.doc.dao.FarmtopDaoInter;
import com.farm.doc.domain.Farmtop;
import com.farm.doc.server.FarmtopServiceInter;

/* *
 *功能:置顶文档服务层实现类
 *详细:
 *
 *版本:v0.1
 *作者:FarmCode代码工程
 *日期:20150707114057
 *说明:
 */
@Service
public class FarmtopServiceImpl implements FarmtopServiceInter {
	@Resource
	private FarmtopDaoInter farmtopDaoImpl;


	@Override
	@Transactional
	public Farmtop insertFarmtopEntity(Farmtop entity, LoginUser user) {
		entity.setCtime(TimeTool.getTimeDate14());
		entity.setCuser(user.getId());
		entity.setCusername(user.getName());
		entity.setPstate("1");
		return farmtopDaoImpl.insertEntity(entity);
	}

	@Override
	@Transactional
	public Farmtop editFarmtopEntity(Farmtop entity, LoginUser user) {
		Farmtop entity2 = farmtopDaoImpl.getEntity(entity.getId());
		entity2.setSort(entity.getSort());
		entity2.setDocid(entity.getDocid());
		entity2.setPcontent(entity.getPcontent());
		farmtopDaoImpl.editEntity(entity2);
		return entity2;
	}

	@Override
	@Transactional
	public void deleteFarmtopEntity(String id, LoginUser user) {

		farmtopDaoImpl.deleteEntity(farmtopDaoImpl.getEntity(id));
	}

	@Override
	@Transactional
	public Farmtop getFarmtopEntity(String id) {

		if (id == null) {
			return null;
		}
		return farmtopDaoImpl.getEntity(id);
	}

	@Override
	@Transactional
	public DataQuery createFarmtopSimpleQuery(DataQuery query) {
		DataQuery dbQuery = DataQuery
				.init(query,
						"FARM_TOP TOP "
								+ "LEFT JOIN FARM_DOC A ON TOP.DOCID = A.ID and a.STATE='1'"
								+ "LEFT JOIN FARM_RF_DOCTYPE B ON B.DOCID =A.ID "
								+ "LEFT JOIN FARM_DOCTYPE C ON C.ID=B.TYPEID "
								+ "LEFT JOIN FARM_DOCGROUP D ON D.ID=A.DOCGROUPID "
								+ "LEFT JOIN FARM_DOCRUNINFO DOCRUNINFO ON A.RUNINFOID = DOCRUNINFO.ID",
						"TOP.ID AS ID, TOP.SORT AS SORT, A.DOCDESCRIBE AS DOCDESCRIBE,A.WRITEPOP AS WRITEPOP,"
						+ "A.READPOP AS READPOP,A.TITLE AS TITLE,A.AUTHOR AS AUTHOR,A.PUBTIME AS PUBTIME,"
						+ "A.DOMTYPE AS DOMTYPE,A.SHORTTITLE AS SHORTTITLE,A.TAGKEY AS TAGKEY,A.STATE AS STATE,"
						+ "D.GROUPNAME AS GROUPNAME, DOCRUNINFO.VISITNUM AS VISITNUM, DOCRUNINFO.ANSWERINGNUM AS ANSWERINGNUM, "
						+ "A.IMGID AS IMGID, A.ID AS DOCID");
		return dbQuery;

	}


	@Override
	public DataQuery docTopChooseDocList(DataQuery query) {
		DataQuery dbQuery = DataQuery
				.init(query,
						"FARM_DOC  A "
								+ "LEFT JOIN FARM_RF_DOCTYPE B ON B.DOCID =A.ID "
								+ "LEFT JOIN FARM_DOCTYPE C ON C.ID=B.TYPEID "
								+ "LEFT JOIN farm_docgroup d ON d.ID=a.DOCGROUPID",
						"A.ID AS ID,A.DOCDESCRIBE as DOCDESCRIBE,A.WRITEPOP as WRITEPOP,A.READPOP as READPOP,A.TITLE AS TITLE,A.AUTHOR AS AUTHOR,A.PUBTIME AS PUBTIME,A.DOMTYPE AS DOMTYPE,A.SHORTTITLE AS SHORTTITLE,A.TAGKEY AS TAGKEY,A.STATE AS STATE,D.GROUPNAME AS GROUPNAME ");
		
		dbQuery.addSqlRule(" AND NOT EXISTS (SELECT 1 FROM FARM_TOP TOP_ WHERE A.ID = TOP_.DOCID) ");
		return dbQuery;

	}

}