From ec64a69276a1a7fa64096d45e2f804fd38d99d17 Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期三, 19 二月 2025 10:50:13 +0800
Subject: [PATCH] 测试完成
---
src/views/patient/propaganda/particty.vue | 413 +++++++++++++++++++++++-----------------------------------
1 files changed, 167 insertions(+), 246 deletions(-)
diff --git a/src/views/patient/propaganda/particty.vue b/src/views/patient/propaganda/particty.vue
index 291facc..290f4fa 100644
--- a/src/views/patient/propaganda/particty.vue
+++ b/src/views/patient/propaganda/particty.vue
@@ -70,21 +70,21 @@
/>
</el-form-item>
<el-form-item label="鏈嶅姟褰㈠紡">
- <el-checkbox-group
+ <el-radio-group
v-model="checkList"
@change="handleCheckedCitiesChange"
>
- <el-checkbox
+ <el-radio
v-for="(item, index) in checkboxlist"
:key="index"
:label="item.value"
@change="checkboxChange($event, item.value)"
>
- {{ item.label }}</el-checkbox
+ {{ item.label }}</el-radio
>
- </el-checkbox-group>
+ </el-radio-group>
</el-form-item>
- <div class="xinz-infs">
+ <!-- <div class="xinz-infs">
<el-form-item label="鏈嶅姟鎵ц椤哄簭" prop="daytime">
<el-tag
:key="tag.label"
@@ -97,13 +97,23 @@
({{ index + 1 }}){{ tag.label }}
</el-tag>
</el-form-item>
- </div>
- <el-form-item label="鏄惁闀挎湡" prop="longTask">
+ </div> -->
+ <el-form-item label="鎵ц鍛ㄦ湡" prop="longTask">
<el-radio-group v-model="form.longTask">
- <el-radio :label="0">鏅�氫换鍔�</el-radio>
+ <el-radio :label="0">鑷畾涔夊懆鏈�</el-radio>
<el-radio :label="1">闀挎湡浠诲姟</el-radio>
</el-radio-group>
</el-form-item>
+ <el-row :gutter="20" v-if="form.longTask">
+ <el-col :span="8">
+ <el-form-item label="鍛ㄦ湡鏃堕棿" prop="name">
+ <el-input
+ v-model="form.sendDay"
+ placeholder="榛樿5澶╁悗"
+ ></el-input>
+ </el-form-item>
+ </el-col>
+ </el-row>
<el-form-item
label="鎵ц璁剧疆"
prop="sendType"
@@ -208,17 +218,19 @@
<el-col :span="20"
><el-form-item label="閫傜敤绉戝" prop="region">
<el-select
- v-model="form.deptcode"
+ v-model="deptcodesWards"
+ @remove-tag="removetag"
style="width: 400px"
size="medium"
filterable
+ multiple
placeholder="璇烽�夋嫨绉戝"
>
<el-option
class="ruleFormaa"
v-for="item in belongDepts"
:key="item.deptCode"
- :label="item.label"
+ :label="item.deptName"
:value="item.deptCode"
>
</el-option>
@@ -228,34 +240,21 @@
<el-row>
<el-col :span="20"
><el-form-item label="閫傜敤鐥呭尯" prop="region">
- <!-- <el-cascader
- style="width: 400px"
- v-model="form.leavehospitaldistrictcode"
- :options="topicoptions"
- :props="propstask"
- :show-all-levels="false"
- clearable
- >
- <template slot-scope="{ node, data }">
- <span>{{ data.deptName }}</span>
- <span v-if="!node.isLeaf">
- ({{ data.children.length }})
- </span>
- </template>
- </el-cascader> -->
<el-select
- v-model="form.leavehospitaldistrictcode"
+ v-model="leavehospitaldistrictcodes"
style="width: 400px"
+ @remove-tag="removehpsp"
size="medium"
filterable
+ multiple
placeholder="璇烽�夋嫨鐥呭尯"
>
<el-option
class="ruleFormaa"
v-for="item in belongWards"
- :key="item.deptCode"
- :label="item.label"
- :value="item.deptCode"
+ :key="item.districtCode"
+ :label="item.districtName"
+ :value="item.districtCode"
>
</el-option>
</el-select> </el-form-item
@@ -448,7 +447,7 @@
</div>
</div>
<el-button type="primary" @click="laststep()">涓婁竴姝�</el-button>
- <el-button type="success" @click="submitForm('ruleForm')">{{
+ <el-button type="success" @click="submitForm('11')">{{
quote ? "绔嬪嵆鍒涘缓" : "纭浠诲姟閰嶇疆"
}}</el-button>
<el-button @click="resetForm('ruleForm')">閲嶇疆</el-button>
@@ -595,90 +594,6 @@
<el-input v-model="objyl.templateName"></el-input>
</div>
</el-form-item>
- <el-form-item label="闅忚鏂瑰紡" prop="suitway">
- <el-select
- style="width: 400px"
- v-model="objyl.suitway"
- size="medium"
- multiple
- filterable
- placeholder="璇烽�夋嫨鍒嗙被"
- >
- <el-option
- class="ruleFormaa"
- v-for="item in mode"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-row :gutter="20" v-if="form.longTask">
- <el-col :span="14">
- <el-form-item label="闀挎湡浠诲姟" prop="longTemp">
- <el-radio-group v-model="objyl.longTemp">
- <el-radio
- v-for="(item, index) in longtype"
- :label="item.value"
- >{{ item.label }}</el-radio
- >
- </el-radio-group>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="浠诲姟鍛ㄦ湡" prop="name">
- <el-input
- v-model="objyl.sendDay"
- placeholder="榛樿5澶╁悗"
- ></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="20"
- ><el-form-item label="閫傜敤绉戝" prop="region">
- <el-select
- style="width: 400px"
- v-model="tempDetpRelevanceslist"
- size="medium"
- multiple
- filterable
- placeholder="璇烽�夋嫨绉戝"
- >
- <el-option
- class="ruleFormaa"
- v-for="item in belongDepts"
- :key="item.deptCode"
- :label="item.label"
- :value="item.deptCode"
- >
- </el-option>
- </el-select> </el-form-item
- ></el-col>
- </el-row>
- <!-- <el-row>
- <el-col :span="20"
- ><el-form-item label="閫傜敤鐥呭尯" prop="region">
- <el-select
- v-model="tempbelongWards"
- style="width: 400px"
- size="medium"
- multiple
- filterable
- placeholder="璇烽�夋嫨鐥呭尯"
- >
- <el-option
- class="ruleFormaa"
- v-for="item in belongWards"
- :key="item.deptCode"
- :label="item.label"
- :value="item.deptCode"
- >
- </el-option>
- </el-select> </el-form-item
- ></el-col>
- </el-row> -->
<div class="xinz-infs">
<el-form-item>
@@ -804,13 +719,13 @@
@click="Departmenttreatment"
>{{ form.templateid ? "鏇挎崲浣跨敤" : "閫夋嫨浣跨敤" }}</el-button
>
- <el-button
+ <!-- <el-button
:type="previewtftype ? 'success' : 'warning'"
@click="Modifytemplate"
>{{
previewtftype ? "鍓嶅線淇敼宸查�夋嫨妯℃澘" : "鏂板淇濆瓨骞跺墠寰�淇敼"
}}</el-button
- >
+ > -->
</span>
</el-dialog>
<el-drawer
@@ -904,14 +819,17 @@
getillness,
Editsingletask,
getFollowupclassify,
+ taskdepthospgetsonlist,
+ taskdepthospgetsondel,
depthospgetsonlist,
} from "@/api/AiCentre/index";
import { deptTreeSelect } from "@/api/system/user";
+import { MessageBox } from "element-ui";
import SFtable from "@/components/SFtable"; //琛ㄦ牸缁勪欢
export default {
- name: "Particty",
+ name: "particty",
data() {
return {
title: "瀹f暀鍐呭鍒楄〃",
@@ -920,6 +838,7 @@
previewid: "", //浠诲姟妯℃澘浼犻�抜d
libName: "",
username: "",
+ templateor: false,
objyl: {},
overallCase: [], //閫夋嫨鎮h�呮��
allpids: [],
@@ -935,6 +854,8 @@
loading: false, // 閬僵灞�
patientloading: false, // 閬僵灞�
dialogVisiblepatient: false, //娣诲姞鎮h�呭脊妗�
+ deptcodesWards: [], //绉戝鏁版嵁
+ leavehospitaldistrictcodes: [], //鐥呭尯鏁版嵁
radio: 1,
checkboxlist: [],
tableLabel: [],
@@ -993,7 +914,7 @@
preachform: [
{ label: "澶氬獟浣�", value: 1 },
{ label: "绾歌川", value: 2 },
- { label: "鐢佃瘽", value: 3 },
+ { label: "鏅鸿兘璇煶", value: 3 },
{ label: "鐭俊", value: 4 },
{ label: "寰俊鍏紬鍙�", value: 5 },
{ label: "寰俊灏忕▼搴�", value: 6 },
@@ -1014,7 +935,7 @@
pageNum: 1, //
pageSize: 10,
},
- checkList: [],
+ checkList: "",
foncheckList: [],
formatvalue: {
format1: "",
@@ -1050,7 +971,7 @@
sonuserList: [], //閫変腑鎮h�呭垪琛�
delvariableList: [], //鍒犻櫎鍙橀噺涓存椂瀛樺偍
longtype: [
- { value: 0, label: "鏅�氫换鍔�" },
+ { value: 0, label: "鑷畾涔夊懆鏈�" },
{ value: 1, label: "闀挎湡浠诲姟" },
],
variableList: [
@@ -1161,17 +1082,12 @@
label: "浣撴闅忚",
},
{
- value: 6,
- label: "婊℃剰搴﹁皟鏌�",
+ value: 11,
+ label: "鍖绘妧闅忚",
},
{
- value: 7,
- label: "鎮h�呮姤鍛�",
- },
-
- {
- value: 8,
- label: "鍏朵粬閫氱煡",
+ value: 10,
+ label: "涓撶闅忚",
},
],
// 绉戝/鐥呭尯
@@ -1195,9 +1111,9 @@
sendType: [
{ required: true, message: "鍙戦�佽缃笉鑳戒负绌�", trigger: "blur" },
],
- deptcode: [
- { required: true, message: "閫傜敤绉戝涓嶈兘涓虹┖", trigger: "blur" },
- ],
+ // deptcode: [
+ // { required: true, message: "閫傜敤绉戝涓嶈兘涓虹┖", trigger: "blur" },
+ // ],
// leavehospitaldistrictcode: [
// { required: true, message: "閫傜敤鐥呭尯涓嶈兘涓虹┖", trigger: "blur" },
// ],
@@ -1216,8 +1132,8 @@
created() {
this.appraiselist = store.getters.appraiselist;
- // this.belongWards = store.getters.belongWards;
- // this.belongDepts = store.getters.belongDepts;
+ this.belongWards = store.getters.belongWards;
+ this.belongDepts = store.getters.belongDepts;
this.username = store.getters.name;
this.mode = store.getters.Askmode;
this.id = this.$route.query.id;
@@ -1228,7 +1144,6 @@
this.form.serviceType = Number(this.$route.query.serviceType);
this.Acquisitiontype();
this.Getdetails();
- this.getDeptTree();
this.getFollowupclassify();
},
activated() {
@@ -1243,7 +1158,6 @@
this.Acquisitiontype();
this.Getdetails();
- this.getDeptTree();
this.getFollowupclassify();
}
},
@@ -1272,14 +1186,7 @@
});
return result;
},
- getDeptTree() {
- // 绉戝鍒楄〃
- deptTreeSelect().then((response) => {
- let flatArray = this.flattenArray(response.data);
- this.belongWards = flatArray;
- this.belongDepts = flatArray;
- });
- },
+
flattenArray(multiArray) {
let result = [];
@@ -1322,7 +1229,6 @@
{
value: "4",
label: "鐭俊",
-
},
{
value: "5",
@@ -1333,12 +1239,11 @@
this.checkboxlist = [
{
value: "3",
- label: "鐢佃瘽",
+ label: "鏅鸿兘璇煶",
},
{
value: "4",
label: "鐭俊",
-
},
{
value: "5",
@@ -1349,10 +1254,10 @@
label: "寰俊灏忕▼搴�",
},
- {
- value: "8",
- label: "鏅鸿兘鏈哄櫒浜�",
- },
+ // {
+ // value: "8",
+ // label: "鏅鸿兘鏈哄櫒浜�",
+ // },
];
} else if (this.form.serviceType == 7 || this.form.serviceType == 5) {
this.checkboxlist = [
@@ -1366,12 +1271,11 @@
},
{
value: "3",
- label: "鐢佃瘽",
+ label: "鏅鸿兘璇煶",
},
{
value: "4",
label: "鐭俊",
-
},
{
value: "5",
@@ -1390,12 +1294,11 @@
},
{
value: "3",
- label: "鐢佃瘽",
+ label: "鏅鸿兘璇煶",
},
{
value: "4",
label: "鐭俊",
-
},
{
value: "5",
@@ -1406,10 +1309,10 @@
label: "寰俊灏忕▼搴�",
},
- {
- value: "8",
- label: "鏅鸿兘鏈哄櫒浜�",
- },
+ // {
+ // value: "8",
+ // label: "鏅鸿兘鏈哄櫒浜�",
+ // },
];
}
getFollowuplist(this.topqueryParams).then((response) => {
@@ -1429,7 +1332,8 @@
});
},
// 淇濆瓨
- submitForm(formName) {
+ submitForm(type) {
+ if (this.templateor && type) this.templateor = false;
if (this.time4 && this.form.sendType == 3)
this.form.showTimeMorn = this.time4;
this.form.sendTimeslot = [
@@ -1439,30 +1343,29 @@
xh: 1,
},
];
- if (
- (this.belongWards[0] || this.belongWards[0]) &&
- this.username == "andmin"
- ) {
- if (this.tempbelongWards[0] || this.tempbelongWards[0]) {
- } else {
- this.$modal.msgError("璇烽�夋嫨绉戝鎴栫梾鍖�");
- return;
- }
- }
- if (this.checkList[0]) {
- this.form.preachform = this.checkList.join(",");
+
+ if (this.checkList) {
+ this.form.preachform = this.checkList;
} else {
this.$modal.msgError("璇烽�夋嫨鏈嶅姟绫诲瀷");
+ return;
+ }
+
+ if (this.deptcodesWards[0] || this.leavehospitaldistrictcodes[0]) {
+ } else {
+ this.$modal.msgError("璇烽�夋嫨绉戝鎴栫梾鍖�");
return;
}
if (!this.form.patTaskRelevances[0] && !this.form.longTask) {
this.$modal.msgError("璇烽�夋嫨鐥呬汉");
return;
}
- if (!this.form.templatename) {
+
+ if (!this.form.templatename && !this.templateor) {
this.$modal.msgError("鏈�夋嫨妯℃澘");
return;
}
+
if ((this.form.sendType == 1 && this.time1) || this.form.sendType == 2) {
} else if (
(this.form.sendType == 3 && this.time4) ||
@@ -1485,18 +1388,14 @@
this.form.type = this.$route.query.type;
}
this.form.serviceType = this.serviceType;
- this.form.leaveldeptcodes = store.getters.belongDepts.map(
- (obj) => obj.deptCode
- );
- this.form.leavehospitaldistrictcodes = store.getters.belongWards.map(
- (obj) => obj.districtCode
- );
+ this.form.deptcode = this.deptcodesWards.join(",");
+ this.form.leavehospitaldistrictcode =
+ this.leavehospitaldistrictcodes.join(",");
Editsingletask(this.form).then((res) => {
if (res.code == 200) {
if (this.form.taskid) {
this.$modal.msgSuccess("淇敼鎴愬姛");
} else {
- this.puttaskid(res.data);
this.$modal.msgSuccess("鏂板鎴愬姛");
}
this.$router.push({
@@ -1506,29 +1405,7 @@
}
});
},
- // 缁欎换鍔℃ā鏉胯祴鍊间换鍔d
- puttaskid(data) {
- getTaskparticty(this.form.templateid).then((res) => {
- if (res.code == 200) {
- this.objyl = res.data;
- this.objyl.isoperation = 2;
- this.objyl.taskid = data.taskId;
- if (!this.objyl.sendDa) {
- this.objyl.sendDay = "5";
- }
- console.log(this.objyl.sendDay, "this.objyl.sendDay");
- Taskparticty(this.objyl).then((response) => {
- this.previewtf = false;
- this.form.libtemplateid = this.objyl.id;
- this.form.templateid = response.data;
- // this.putbelongDepts(response.data);
- this.form.templatename = this.objyl.templateName;
- this.$modal.msgSuccess("閫夋嫨妯℃澘鎴愬姛");
- });
- }
- });
- },
// ----------------------琛ㄦ牸瀛愮粍浠朵簨浠�
// 閫夋嫨棰勮
@@ -1541,13 +1418,13 @@
getvFollowup({ id: row.id }).then((res) => {
if (res.code == 200) {
this.objyl = res.data;
- if (this.form.longTask) {
- this.objyl.sendDay = 5;
- }
+ // if (this.form.longTask) {
+ // this.objyl.sendDay = 5;
+ // }
this.queryParamsdept.type = 2;
this.queryParamsdept.tempid = row.id;
- this.listDept();
-
+ this.tempDetpRelevanceslist = [];
+ this.tempbelongWards = [];
this.objyl.suitway = this.objyl.suitway.split(",");
this.questionList = res.data.ivrLibaTemplateScriptVOList;
this.getillness(row.id);
@@ -1571,8 +1448,7 @@
this.queryParamsdept.type = 21;
// 鐤剧梾
this.getillness(this.form.libtemplateid);
- // 鎵ц鑾峰彇璇ヤ换鍔℃ā鏉縤d
- this.listDept();
+
getvFollowup({ id: this.form.libtemplateid }).then((res) => {
if (res.code == 200) {
this.previewtf = true;
@@ -1723,6 +1599,9 @@
item.deptName = item.dept;
item.admindate = item.inhosptime;
item.sfzh = item.idcardno;
+ if (this.patientqueryParams.allhosp==6) {
+ item.patfrom = 1;
+ }
this.overallCase.push(item);
this.form.patTaskRelevances.push(item);
}
@@ -1757,8 +1636,6 @@
this.$modal
.confirm('鏄惁纭鍒犻櫎鎮h��"' + row.name + '"鐨勬湇鍔¢」锛�')
.then(() => {
- console.log();
-
let indexa = this.overallCase.indexOf(row);
let indexb = this.form.patTaskRelevances.indexOf(row);
this.overallCase.splice(indexa, 1);
@@ -1784,9 +1661,15 @@
store.getters.leavehospitaldistrictcodes;
this.patientqueryParams.leaveldeptcodes = null;
}
- if (!this.patientqueryParams.leavehospitaldistrictcodes||!this.patientqueryParams.leavehospitaldistrictcodes[0])
+ if (
+ !this.patientqueryParams.leavehospitaldistrictcodes ||
+ !this.patientqueryParams.leavehospitaldistrictcodes[0]
+ )
this.patientqueryParams.leavehospitaldistrictcodes = null;
- if (!this.patientqueryParams.leaveldeptcodes||!this.patientqueryParams.leaveldeptcodes[0])
+ if (
+ !this.patientqueryParams.leaveldeptcodes ||
+ !this.patientqueryParams.leaveldeptcodes[0]
+ )
this.patientqueryParams.leaveldeptcodes = null;
this.handleAddpatient();
},
@@ -1818,6 +1701,7 @@
this.form = {
patTaskRelevances: [],
sendType: 1,
+ sendDay: 5,
templatename: "",
templateid: null,
libtemplateid: null,
@@ -1836,7 +1720,7 @@
? this.form.patTaskRelevances
: [];
this.overallCase = this.form.patTaskRelevances.concat();
- this.checkList = this.form.preachform.split(",");
+ this.checkList = this.form.preachform;
this.overallCase.forEach((item) => {
if (item.endtime) {
@@ -1851,6 +1735,9 @@
} else {
this.time1 = this.form.showTimeMorn.split(",");
}
+ }
+ if (this.form.taskid) {
+ this.listDept();
}
if (this.form.showTimeNoon)
this.time2 = this.form.showTimeNoon.split(",");
@@ -1885,22 +1772,48 @@
},
// 鑾峰彇绉戝鍒楄〃
listDept() {
- this.tempDetpRelevanceslist = [];
- this.tempbelongWards = [];
- depthospgetsonlist(this.queryParamsdept).then((res) => {
+ this.leavehospitaldistrictcodes = [];
+ this.deptcodesWards = [];
+ this.queryParamsdept.taskId = this.form.taskid;
+ taskdepthospgetsonlist(this.queryParamsdept).then((res) => {
if (res.code == 200) {
let arr = res.rows;
arr.forEach((item) => {
if (item.deptType == 1) {
this.deptlist.push(item);
- this.tempDetpRelevanceslist.push(item.deptCode);
+ this.deptcodesWards.push(item.deptCode);
} else if (item.deptType == 2) {
this.hosplist.push(item);
- this.tempbelongWards.push(item.deptCode);
+ this.leavehospitaldistrictcodes.push(item.deptCode);
}
});
}
});
+ },
+ // 浠诲姟绉戝鍒犻櫎瑙﹀彂
+ removetag(row) {
+ let result = this.deptlist
+ .filter((item) => item.deptCode == row)
+ .map((item) => item.id);
+
+ if (result.length) {
+ taskdepthospgetsondel(result).then((res) => {
+ if (res.code) {
+ }
+ });
+ }
+ },
+ // 闄㈠尯鍒犻櫎鍒犻櫎瑙﹀彂
+ removehpsp(row) {
+ let result = this.hosplist
+ .filter((item) => item.deptCode == row)
+ .map((item) => item.id);
+ if (result.length) {
+ taskdepthospgetsondel(result).then((res) => {
+ if (res.code) {
+ }
+ });
+ }
},
getFollowupclassify() {
getFollowupclassify({}).then((res) => {
@@ -2005,9 +1918,9 @@
if (this.form.id) {
this.objyl.taskid = this.form.id;
}
- if (!this.objyl.sendDay) {
- this.objyl.sendDay = "5";
- }
+ // if (!this.objyl.sendDay) {
+ // this.objyl.sendDay = "5";
+ // }
if (this.form.templateid) {
deleteTaskparticty(this.form.templateid).then((res) => {
if (res.code == 200) {
@@ -2087,34 +2000,42 @@
this.foncheckList = this.foncheckList.filter(
(obj) => obj.value !== tag.value
);
- console.log(this.checkList, "checkList");
},
// 绉戝澶勭悊
Departmenttreatment() {
- this.tempDetpRelevanceslist.forEach((item) => {
- this.tempDetpRelevanceslistform.push({
- deptType: 1,
- longTemp: this.form.longTask,
- deptCode: item,
- tempid: null,
- type: 21,
- });
- });
+ if (!this.form.taskid) {
+ this.templateor = true;
+ MessageBox.confirm(
+ "褰撳墠涓烘柊澧炰换鍔℃湭淇濆瓨涓嶅彲鍏宠仈妯℃澘锛屾槸鍚﹀厛淇濆瓨浠诲姟锛�",
+ "鍔熻兘鎻愮ず",
+ {
+ confirmButtonText: "淇濆瓨浠诲姟",
+ cancelButtonText: "鍙栨秷",
+ type: "warning",
+ }
+ )
+ .then(() => {
+ if (Array.isArray(this.objyl.suitway)) {
+ this.objyl.suitway = this.objyl.suitway.join(",");
+ }
+ this.objyl.templateid = this.objyl.id;
+ this.objyl.isoperation = 1;
+ this.objyl.ivrLibaTemplateScriptVOList.forEach((item) => {
+ item.ivrTaskScriptTargetoptionList =
+ item.ivrLibaScriptTargetoptionList;
+ });
+ this.objyl.ivrTaskTemplateScriptVOList =
+ this.objyl.ivrLibaTemplateScriptVOList;
+ this.form.ivrTaskTemplateVO = this.objyl;
- this.tempbelongWards.forEach((item) => {
- this.tempbelongWardsform.push({
- deptType: 2,
- longTemp: this.form.longTask,
- deptCode: item,
- tempid: null,
- type: 21,
- });
- });
- console.log(33);
-
- setTimeout(() => {
- this.previewFn();
- }, 1000);
+ this.submitForm();
+ })
+ .catch(() => {});
+ } else {
+ setTimeout(() => {
+ this.previewFn();
+ }, 1000);
+ }
},
// 鍓嶅線淇敼
Modifytemplate() {
--
Gitblit v1.9.3