#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
	demeter web
	name:work.py 农事相关
	author:rabin
"""
from __load__ import *

class index_path(Load):
	"""
	@api {get} /work 获取农事记录列表
	@apiVersion 1.0.0
	@apiName getWorkList
	@apiGroup Farm

	@apiParam {String} page 页数

	@apiSuccess {Object[]} setting 基本信息
	@apiSuccess {String}   setting.name  站点名
	@apiSuccess {Number}   setting.farm  当前的农场ID

	@apiSuccess {Object[]} list 农事列表信息
	@apiSuccess {String}   list.name  名称
	@apiSuccess {String}   list.id	ID

	@apiSuccess {Object[]} page 分页信息
	@apiSuccess {String}   page.current  当前页
	@apiSuccess {String}   page.total	总页数
	@apiSuccess {String}   page.num	每页数据条数
	@apiSuccess {String}   page.totalNum	总数据条数

	@apiErrorExample 操作成功
	
	{"status": 1, "msg": "yes", "code": 0, "data": {"setting": {"farm": 1, "user": "229cfd36-9399-5599-b2b5-c53174c3de19", "name": "\u519c\u5c0f\u76d2", "copyright": "2017 nongxiaohe.com v1.0.0", "site": "http://www.nongxiaohe.com/"}, "list": [{"category": "\u7528\u836f", "workdates": "2017-10-11", "pic": "http://www.xinnongbaohe.com:8087/upload/2017/10/10/36083979c0984547320137e5f01f7e52.jpg", "name": "2017-10-11 - \u5730\u57572\u53f7/\u7528\u836f", "land_id": "6b18f8b5-c9e5-5600-8808-dad30fa4ea93", "farm_id": 1, "state": true, "content": "22222", "amount": "30L222", "workdate": 1507680000, "category_id": "fcd8899a-a3a5-52ee-a2a8-2d5c30160044", "cdate": 1509347365, "id": "ee57691d-d4e7-533c-9111-3fc059120a7b", "land": "\u5730\u57572\u53f7"}], "page": {"current": 1, "ajax": false, "total": 1, "num": 15, "totalNum": 1}, "base": {}}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def get(self):
		self.data['list'] = self.service('common').list('farm_work', state=True)
		if self.data['list']:
			for key, value in enumerate(self.data['list']):
				self.data['list'][key]['workdates'] = Demeter.date(value['workdate'], '%Y-%m-%d')
				category = self.service('common').one('farm_work_category', id=value['category_id'])
				self.data['list'][key]['category'] = category['name']
				land = self.service('common').one('farm_work_land', id=value['land_id'])
				if land:
					self.data['list'][key]['land'] = land['name']
					self.data['list'][key]['name'] = self.data['list'][key]['workdates'] + ' - ' + land['name'] + '/' + category['name']
				else:
					self.data['list'][key]['name'] = self.data['list'][key]['workdates'] + '/' + category['name']
		self.out('yes', self.data)

	"""
	@api {post} /work 更新农事记录
	@apiVersion 1.0.0
	@apiName updateWork
	@apiGroup Farm

	@apiParam {String} id 农事ID,为空则插入新记录
	@apiParam {String} update_pic 图片,多个逗号隔开
	@apiParam {String} update_category 农事方式ID
	@apiParam {String} update_land 地块ID
	@apiParam {String} update_workdate 农事时间:2017-10-10
	@apiParam {String} update_content 劳作内容
	@apiParam {String} update_amount 劳作数量

	@apiSuccess {Bool} status 状态
	@apiSuccess {String}   msg  描述
	@apiSuccess {Number}   code  状态码

	@apiErrorExample 操作成功
	{"status": 1, "msg": "操作成功", "code": 0, "data": {}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def post(self):
		id = self.input('id', None)
		update = {}
		update['pic'] = self.input('update_pic')
		update['category_id'] = self.input('update_category')
		update['land_id'] = self.input('update_land')
		update['workdate'] = self.input('update_workdate')
		update['content'] = self.input('update_content')
		update['amount'] = self.input('update_amount')
		if not update['category_id']:
			self.out(u'请选择农事方式')
			return
		if not update['land_id']:
			self.out(u'请选择地块')
			return
		if not update['workdate']:
			self.out(u'请输入农事时间')
			return
		if not update['content']:
			self.out(u'请输入劳作内容')
			return
		if not update['amount']:
			self.out(u'请输入劳作数量')
			return
		#update['workdate'] = Demeter.mktime(update['workdate'], '%Y-%m-%d')
		state = self.service('common').update('farm_work', id, update, cdate=False)
		self.out('yes', {'id':state})

class info_path(Load):
	"""
	@api {get} /work/info 获取农事信息
	@apiVersion 1.0.0
	@apiName getWorkInfo
	@apiGroup Farm

	@apiParam {String} id 农事ID

	@apiSuccess {Object[]} setting 基本信息
	@apiSuccess {String}   setting.name  站点名
	@apiSuccess {Number}   setting.farm  当前的农场ID

	@apiSuccess {Object[]} info 农事信息
	@apiSuccess {String}   info.name  名称
	@apiSuccess {String}   info.id  ID
	@apiErrorExample 操作成功
	{"status": 1, "msg": "yes", "code": 0, "data": {"setting": {"farm": 1, "user": 0, "name": "\u519c\u5c0f\u76d2", "copyright": "2017 nongxiaohe.com v1.0.0", "site": "http://www.nongxiaohe.com/"}, "list": [{"pic": "http://192.168.15.10:8087/upload/2017/08/30/455f9d6c26b5c989b32eda1809e58d5f.jpg", "method_id": null, "land_id": "249be20d-5759-5af0-9859-b770d9f44e2a", "farm_id": 1, "state": true, "amount": "100ml", "workdate": 1504105397, "category_id": "9365ea66-be55-56f7-a511-059fc85a9478", "cdate": 1504076614, "id": "19e05f00-ae55-5605-be12-86dcd2866df9"}], "page": {"current": 1, "ajax": false, "total": 1.0, "num": 15, "totalNum": 1}}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def get(self):
		id = self.input('id', None)
		if id:
			self.data['info'] = self.service('common').one('farm_work', id=id)
			if self.data['info']:
				self.data['info']['workdates'] = Demeter.date(self.data['info']['workdate'], '%Y-%m-%d')
				
			self.out('yes', self.data)
		else:
			self.out('no')

class land_path(Load):
	"""
	@api {get} /work/land 获取农事地块列表
	@apiVersion 1.0.0
	@apiName getWorkLandList
	@apiGroup Farm

	@apiSuccess {Object[]} setting 基本信息
	@apiSuccess {String}   setting.name  站点名
	@apiSuccess {Number}   setting.farm  当前的农场ID

	@apiSuccess {Object[]} list 地块列表信息
	@apiSuccess {String}   list.name  名称
	@apiSuccess {String}   list.id	ID
	@apiErrorExample 操作成功
	{"status": 1, "msg": "yes", "code": 0, "data": {"setting": {"farm": 1, "user": "229cfd36-9399-5599-b2b5-c53174c3de19", "name": "\u519c\u5c0f\u76d2", "copyright": "2017 nongxiaohe.com v1.0.0", "site": "http://www.nongxiaohe.com/"}, "list": [{"state": true, "farm_id": 1, "cdate": 1509344166, "id": "6b18f8b5-c9e5-5600-8808-dad30fa4ea93", "name": "\u5730\u57572\u53f7"}, {"state": true, "farm_id": 1, "cdate": 1509344164, "id": "17b881d4-ea79-5968-8328-4d7587cf3e39", "name": "\u5730\u57571\u53f7"}], "base": {}}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def get(self):
		self.data['list'] = self.service('common').list('farm_work_land', state=True)
		self.out('yes', self.data)

	"""
	@api {post} /work/land 更新地块
	@apiVersion 1.0.0
	@apiName updateWorkLand
	@apiGroup Farm

	@apiParam {String} id 地块ID,为空则插入新记录
	@apiParam {String} update_name 地块名称

	@apiSuccess {Bool} status 状态
	@apiSuccess {String}   msg  描述
	@apiSuccess {Number}   code  状态码

	@apiErrorExample 操作成功
	{"status": 1, "msg": "操作成功", "code": 0, "data": {}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def post(self):
		id = self.input('id', None)
		update = {}
		update['name'] = self.input('update_name')
		if not update['name']:
			self.out(u'请输入地块名称')
			return
		state = self.service('common').update('farm_work_land', id, update, cdate=False)
		self.out('yes', {'id':state})

	"""
	@api {delete} /work/land 删除地块
	@apiVersion 1.0.0
	@apiName deleteWorkLand
	@apiGroup Farm

	@apiParam {String} id 地块ID,为空则插入新记录

	@apiSuccess {Bool} status 状态
	@apiSuccess {String}   msg  描述
	@apiSuccess {Number}   code  状态码

	@apiErrorExample 操作成功
	{"status": 1, "msg": "操作成功", "code": 0, "data": {}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def delete(self):
		id = self.input('id')
		if id:
			model = Demeter.model('farm_work_land')
			model.id = id
			model.delete()
		self.out('yes', {'id':id})

class land_pic_path(Load):
	"""
	@api {get} /work/land_pic 获取农事地块图片列表
	@apiVersion 1.0.0
	@apiName getWorkLandPicList
	@apiGroup Farm

	@apiSuccess {Object[]} setting 基本信息
	@apiSuccess {String}   setting.name  站点名
	@apiSuccess {Number}   setting.farm  当前的农场ID

	@apiSuccess {Object[]} list 地块列表信息
	@apiSuccess {String}   list.name  名称
	@apiSuccess {String}   list.id	ID
	@apiSuccess {Object[]}   list.pic	图片

	@apiErrorExample 操作成功
	{"status": 1, "msg": "yes", "code": 0, "data": {"setting": {"farm": 1, "user": "229cfd36-9399-5599-b2b5-c53174c3de19", "name": "\u519c\u5c0f\u76d2", "copyright": "2017 nongxiaohe.com v1.0.0", "site": "http://www.nongxiaohe.com/"}, "list": [{"farm_id": 1, "name": "222", "pic": [{"pic": "http://192.168.15.10:8088/upload/2017/11/01/a7164193b56a074d72e4f94e4a4d145c.jpg", "land_id": "d508f554-db86-52dc-ba20-fbb476c60abc", "farm_id": 1, "state": true, "cdate": 1509519631, "id": "0d11d5ee-990e-52d5-ae55-09a212834f0d"}], "cdate": 1509519537, "state": true, "id": "d508f554-db86-52dc-ba20-fbb476c60abc"}, {"farm_id": 1, "name": "111", "pic": [], "cdate": 1509519533, "state": true, "id": "03679a19-f619-55d3-959c-bbc0a22dc072"}], "base": {}}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def get(self):
		self.data['list'] = self.service('common').list('farm_work_land', state=True)
		#self.data['list'] = self.service('common').list('farm_work_land_pic', state=True)
		if self.data['list']:
			for key, value in enumerate(self.data['list']):
				self.data['list'][key]['pic'] = self.service('common').list('farm_work_land_pic', search={'land_id':value['id']}, state=True)
		self.out('yes', self.data)

	"""
	@api {post} /work/land_pic 更新地块图片
	@apiVersion 1.0.0
	@apiName updateWorkLandPic
	@apiGroup Farm

	@apiParam {String} update_land_id 地块ID,为空则插入新记录
	@apiParam {String} update_pic 地块图片地址

	@apiSuccess {Bool} status 状态
	@apiSuccess {String}   msg  描述
	@apiSuccess {Number}   code  状态码

	@apiErrorExample 操作成功
	{"status": 1, "msg": "操作成功", "code": 0, "data": {}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def post(self):
		id = self.input('id', None)
		update = {}
		update['land_id'] = self.input('update_land_id')
		update['pic'] = self.input('update_pic')
		if not update['land_id']:
			self.out(u'请选择地块')
			return
		if not update['pic']:
			self.out(u'请上传地块图片')
			return
		state = self.service('common').update('farm_work_land_pic', id, update, cdate=False)
		self.out('yes', {'id':state})

class category_path(Load):
	"""
	@api {get} /work/category 获取农事分类列表
	@apiVersion 1.0.0
	@apiName getWorkCateList
	@apiGroup Farm

	@apiSuccess {Object[]} setting 基本信息
	@apiSuccess {String}   setting.name  站点名
	@apiSuccess {Number}   setting.farm  当前的农场ID

	@apiSuccess {Object[]} list 分类列表信息
	@apiSuccess {String}   list.name  名称
	@apiSuccess {String}   list.id	ID
	@apiErrorExample 操作成功
	{"status": 1, "msg": "yes", "code": 0, "data": {"setting": {"farm": 1, "user": "229cfd36-9399-5599-b2b5-c53174c3de19", "name": "\u519c\u5c0f\u76d2", "copyright": "2017 nongxiaohe.com v1.0.0", "site": "http://www.nongxiaohe.com/"}, "list": [{"state": true, "farm_id": 1, "cdate": 1509344125, "id": "fcd8899a-a3a5-52ee-a2a8-2d5c30160044", "name": "\u7528\u836f"}, {"state": true, "farm_id": 1, "cdate": 1509344107, "id": "6f955928-9724-5cb7-acd0-a81d482d9883", "name": "\u65bd\u80a5"}], "base": {}}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def get(self):
		self.data['list'] = self.service('common').list('farm_work_category', state=True)
		self.out('yes', self.data)

	"""
	@api {post} /work/category 更新农事分类
	@apiVersion 1.0.0
	@apiName updateWorkCategory
	@apiGroup Farm

	@apiParam {String} id 分类ID,为空则插入新记录
	@apiParam {String} update_name 分类名称

	@apiSuccess {Bool} status 状态
	@apiSuccess {String}   msg  描述
	@apiSuccess {Number}   code  状态码

	@apiErrorExample 操作成功
	{"status": 1, "msg": "操作成功", "code": 0, "data": {}}
	@apiErrorExample 操作失败
	{"status": 2, "msg": "\u64cd\u4f5c\u5931\u8d25", "code": 0, "data": {}}
	"""
	@auth
	@Web.setting
	def post(self):
		id = self.input('id', None)
		update = {}
		update['name'] = self.input('update_name')
		if not update['name']:
			self.out(u'请输入分类名称')
			return
		state = self.service('common').update('farm_work_category', id, update, cdate=False)
		self.out('yes', {'id':state})